首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Jquery ajax facebox

Jquery ajax facebox
EN

Stack Overflow用户
提问于 2011-01-08 22:22:49
回答 2查看 1.2K关注 0票数 1

我有一个"live search“类型的页面,它使用ajax调用另一个页面来检查输入的有效性。它返回一个图像,您可以单击该图像以查看有关该产品的更多信息。这张图片有一个rel=" facebox“属性,当点击时会弹出一个包含div信息的facebox。但是,我必须在图像上单击两次才能加载facebox。下面是我使用的Jquery live代码:

代码语言:javascript
复制
            jQuery(document).ready(function($) {

            $('a[rel*=facebox]').live("click", function() {
                $(this).facebox();
            });
        });

提前感谢!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-01-08 22:35:03

发生的事情是,你正在初始化 facebox onclick。第一个调用将向click event添加一个句柄来打开facebox,所以如果您在接收这些实时结果时没有回调来执行此操作,则必须执行以下操作:

代码语言:javascript
复制
$('a[rel*=facebox]').live("click", function() {
    $(this).unbind("click").facebox().trigger("click");
    return false;
}

但这很丑陋:-(。甚至有可能,当你使用"live“时,当一些新的元素到达时,事件将被重新绑定到元素:S你可以用console.log来验证这一点。

一种更简洁的方法是向facebox添加一个初始化属性,名为autoStart或类似的属性,它将初始化facebox,并在相同的函数中打开它。

祝好运!

票数 2
EN

Stack Overflow用户

发布于 2011-01-08 22:35:52

仅使用此选项:

代码语言:javascript
复制
$(function(){
    $('a[rel*=facebox]').facebox();
});

或者甚至删除*(如果这是链接上唯一的类),它将创建facebox div结构,当您使用它与click事件时,第一次单击将生成div,第二次单击将打开facebox。

哦,还有一件事,因为内容是动态生成的,所以您可以使用回调来运行这行代码来重新附加click事件。

干杯

G.

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4634292

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档