如何使用 iScroll 处理多个 DOM 元素(使用 jQTouch 时)
我的标记是
<div id="home" class="current">
<div class="header">iScroll</div>
<div class="wrapper">
<div id="scroller">
<ul id="thelist" class="plastic"><!-- li items --></ul>
</div>
</div>
<div class="footer">Footer</div>
</div>
<!-- Events Details -->
<div id="events">
<div class="header">iScroll</div>
<div class="wrapper">
<div id="scroller"> <!-- stuffsss --></div>
</div>
<div class="footer">Footer</div>
</div>
为了让 iScroll (http://cubiq.org/iscroll) 工作,我需要 #scroller
作为 ID(根据我用来初始化 iScroll 的 javascript 代码)。
//for iScroll
var myScroll = new iScroll('scroller', {desktopCompatibility:true});
// Load iScroll when DOM content is ready.
document.addEventListener('DOMContentLoaded', loaded, false);
iScroll 无法正常工作。
但由于我不能有两个具有相同 ID 的不同元素(请注意,上面的标记中有两个具有相同 id 滚动条的元素),因此存在一些冲突,并且我希望 能够通过将 id 更改为类来实现标记上的 iScroll 我尝试将它们更改为类,看看它是否有效,但我无法正确地
更改代码,以便它通过实现类而不是 the 来工作。 ID??
I've my markups as
<div id="home" class="current">
<div class="header">iScroll</div>
<div class="wrapper">
<div id="scroller">
<ul id="thelist" class="plastic"><!-- li items --></ul>
</div>
</div>
<div class="footer">Footer</div>
</div>
<!-- Events Details -->
<div id="events">
<div class="header">iScroll</div>
<div class="wrapper">
<div id="scroller"> <!-- stuffsss --></div>
</div>
<div class="footer">Footer</div>
</div>
For iScroll (http://cubiq.org/iscroll) to work, I need the #scroller
as ID (as per the javascript Code I'm using to initialize iScroll.
//for iScroll
var myScroll = new iScroll('scroller', {desktopCompatibility:true});
// Load iScroll when DOM content is ready.
document.addEventListener('DOMContentLoaded', loaded, false);
But since I can't have two different elements with the same ID (please notice I've got two elements with same id scroller in my markup above), some conflicts are there and the iScroll isn't working properly.
I want to be able to implement the iScroll on the markup by changing the id as classes. I tried to change them into classes and see if it works but I couldnt get it right.
Can anyone help me change the codes so that it works by implementing classes instead of the the id??
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
罗布是对的,但您可以按照您所说的将代码更改为滚动器类。
然后在独特的包装器中初始化滚动条,如下所示:
Rob is right, but you can change your code to scroller classes as you said.
Then initialise your scrollers within unique wrappers like this:
我不完全清楚您想要实现的目标,但如果您希望页面的两个部分滚动,我建议将 ID 更改为唯一,并使用不同的 ID 实例化两个 iScroll。
I'm not totally clear on what you are trying to achieve but if you want two parts of your page to scroll I would suggest changing the IDs to be unique and instantiate two iScrolls with the different IDs.
我相信您已经弄清楚了,但对于其他用户来说,仍然在为类似的布局(多个滚动条)而苦苦挣扎,并希望它们能够工作。这是其他线程的答案
https://stackoverflow.com/a/7584694/1232232
但要让这个对你有用需要为您的分类(div 容器)分配 ID
注意
:记住不要将相同的 ID 分配给多个元素,始终使用类来实现此目的。
I am sure you have figured it out, but for other users still struggling with similar layout (multiple scrollers) and want to make them work. Here is the answer from other thread
https://stackoverflow.com/a/7584694/1232232
but for this to work you need to assign ID's to your classed (div containers)
like
Note: Remember not to assign same ID to multiple elements, always use classes for that purpose.