当HTML/LINK通过ajax加载时,jQueryTOOLS覆盖灯箱不起作用



在开始之前,我已经研究并发现了这个类似的问题:重新初始化ajax加载元素上的jQuerytools Overlay

然而,这个问题的"答案"建议使用.live()。我试图我们jQuery 1.9 .live()不是一个函数来更新使用。on()。
$(".overlay_load[rel]").on('click', 'a', function () {
    $(this).overlay().load();
    $(this).overlay().load();
    return false;
});

我承认我不是百分之百地理解这是在做什么,除了可能重新初始化新加载的HTML,以便jQueryTOOLS Overlay可以"访问"新加载的HTML。

我有一个页面通过AJAX加载HTML内容的部分。下面是一个DIV被加载的例子:

<div class="ajax-returned mytop">
    <span class="username"> drkwong </span> <br> 
    <span class="full-name">Andrew Kwong</span><br> 
    <span class="action-status"> 
        <span class="mt-icon ut3"></span> 
        <span class="autoship active">A</span>
        <span class="view_profile">
            <a href="/member/downline_tree_view/?view=tree_profile&amp;program=1&amp;view_userid=13" rel="#overlay">
                <img src="/inc/downline_tree/images/more_info.png" rel="#13">
            </a>
        </span> 
    </span>
</div>
<!-- overlayed element -->
<div class="apple_overlay" id="overlay">
    <!-- the external content is loaded inside this tag -->
    <div class="contentWrap"></div>
</div>

这个链接应该使用jQuery,然后加载一个jQueryTOOLS叠加灯箱:

    <script>
            $(function() {
                // if the function argument is given to overlay,
                // it is assumed to be the onBeforeLoad event listener
                $("a[rel]").overlay({
                    mask: 'grey',
                    effect: 'apple',
                    onBeforeLoad: function() {
                        // grab wrapper element inside content
                        var wrap = this.getOverlay().find(".contentWrap");
                        // load the page specified in the trigger
                        wrap.load(this.getTrigger().attr("href"));
                    }
                });
            });
    </script>

这是我用来加载一个外部页面到灯箱的jQuery: http://jquerytools.github.io/demos/overlay/external.html

感觉就像没有触发jQuery。

标题如下:

<script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
<script type="text/javascript" src="/templates/public/2/downline/js/jquery.browser.min.js"></script>
<script type="text/javascript" src="/templates/public/2/downline/js/jquery.tools.min.js"></script>
jQueryTOOLS Overlay需要jquery.browser.min.js来访问浏览器。https://github.com/gabceb/jquery-browser-plugin 编辑:

AJAX

var ids=new Array()
var node
var param={"action":"NodeDetailAll","admin":"1"}
var users=new Array()

function get_ids(){
    for(var i=0;i<nodes.length;i++){
        users.push("child_"+$(nodes[i]).attr("class"))
        ids.push($(nodes[i]).attr("class"))
    }
}
function get_nodes(){
    nodes = $("#chart [myattr*='descendent']")
    nodes= jQuery.makeArray(nodes);
    $.when(get_ids()).then(function(){
        $.each(ids,function(key,value){
            param[users[key]]=value
        })
    })        
}
function write_html(response){
    $.each(response,function(key,value){
      $("."+key).html(value)
    })
}
jQuery(document).ready(function() {
    $(".spinner-loader").fadeIn(200)
    $.when(get_nodes()).then(function(){
        $.post("~ajax_url~",param,function(response) { 
            response=jQuery.parseJSON(response)
            $.when(write_html(response)).done(function() {
                $(".spinner-loader").fadeOut(600)
                $("#chart").css("opacity","1")
                // is this where I would add the on()? //
                // I tried that, without success.  //
                // perhaps I need to modify the on() function? //
            })
        })
    })
})

您可以在ajax函数的回调上调用覆盖绑定。另一件事是检查您的jQuery选择器,以确保您已经正确地配置了它们,并且它们正在选择适当的元素来绑定您的事件。

根据jQuery文档:"事件处理程序只绑定到当前选定的元素;它们必须在代码调用.on()时存在于页面上。

所以在我看来,在AJAX请求的回调中调用绑定功能是可行的!也许如果你能提供一个简化版本的代码,ajax请求包括,然后我可以试着再看一眼:)

使用不同的解决方案。jQueryTOOLS Overlay不再活跃,并使用过时甚至被淘汰的jQuery函数。试图解决所有这些问题已经被证明是低效的,而且就AJAX而言,与最新版本的jQuery是不可能的。

@sparky FancyBox 2提供了所需的解决方案。

最新更新