jQuery contentcarousel 克隆绑定事件失败

发布于 2024-12-19 16:10:34 字数 815 浏览 0 评论 0原文

我正在使用 jQuery 轮播来循环滚动一些项目。

我需要满足以下条件:

  • 当单击第一项并单击“后退”按钮时,必须显示最后一项。
  • 当在最后一个项目上单击“下一个”按钮时,必须显示第一个项目。

轮播中的元素是绑定了点击事件的 a 标签。这些项目以循环方式显示,但是当我单击 case1 和 case2 事件之后的项目时,不会触发。

克隆项目后,锚点不会绑定到事件并且不会触发。我的锚点 onclick 函数使用命名空间函数。

注意:我的代码使用 clone(true)

代码:

<a title="click me" href="" id="elementid"> 
    <xsl:attribute name="behavior.ID">GoClick</xsl:attribute>
    <xsl:attribute name="behavior.autobind.GoClick">onclick</xsl:attribute>
    <xsl:attribute name="behavior.GoClick.streamname">
        <xsl:value-of select="streamname" />
    </xsl:attribute> 
    click me 
</a> 

public void GoClickEventHandler(sender,args) { //do something here } 

I am using jQuery carousel to scroll some items in a loop.

I have the following conditions to meet:

  • When at the first item and the 'back' button is clicked, the last item has to shown.
  • When at the last item and the 'next' button is clicked, the first item has to shown.

The elements in the carousel are a tags with click events bound to them. The items are shown in circular way but when I click items after case1 and case2 events are not fired.

After clone of items, the anchor is not bound to events and are not firing. My anchor onclick function is using a namespaced function.

Note: my code uses clone(true)

Code:

<a title="click me" href="" id="elementid"> 
    <xsl:attribute name="behavior.ID">GoClick</xsl:attribute>
    <xsl:attribute name="behavior.autobind.GoClick">onclick</xsl:attribute>
    <xsl:attribute name="behavior.GoClick.streamname">
        <xsl:value-of select="streamname" />
    </xsl:attribute> 
    click me 
</a> 

public void GoClickEventHandler(sender,args) { //do something here } 

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

古镇旧梦 2024-12-26 16:10:34

我在这里猜测没有看到您的代码,但是因为您在页面加载后动态创建元素,所以您将需要使用 live()delegate() 进行绑定它们的事件处理程序,而不是 click()

Live() 的使用方式如下:

$("#myAnchor").live("click", function() {
    // stuff to do on click
});

delegate() (性能更好)的使用方式如下:

$("#anchorParent").delegate("#myAnchor", "click", function() {
    // stuff to do on click
});

Without seeing your code I'm guessing here, but because you are creating elements dynamically after the page has loaded you will need to use live() or delegate() to bind the event handlers to them, instead of click().

Live() is used like this:

$("#myAnchor").live("click", function() {
    // stuff to do on click
});

And delegate() (which has better performance) is used like this:

$("#anchorParent").delegate("#myAnchor", "click", function() {
    // stuff to do on click
});
挥剑断情 2024-12-26 16:10:34

要使 jQuery 轮播成为循环,您必须执行以下操作:

// Looping carousel
$("div").carousel( { loop: true } );

loop: true 选项将使其循环。

For the jQuery carousel to be circular you have to do this:

// Looping carousel
$("div").carousel( { loop: true } );

The loop: true option will make it circular.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文