在我在Firebug中设置断点之前,jQuery不会执行

时间:2015-07-10 14:55:13

标签: javascript jquery html symfony firebug

我正在使用twig生成我的html内容和外部js文件来调用jQuery(document).ready(function() {....});这可能是一个简单的问题,但我无法弄明白。

这是我的代码: base.html.twig

<script>
    var currentPage = "{{ path(app.request.attributes.get('_route'),app.request.attributes.get('_route_params')) }}".replace(/[0-9]|\//g, '').toLowerCase().replace('app_dev.php', '');
    $.ajax({
        type: 'GET',
        url: "{{ asset('/app_dev.php/GetMenuJson/') }}" + currentPage,
        success: function(data){
            constructMenuData(data);
        }
    });
    function constructMenuData(menuData)
    {
        var contentForDiv = "";
        //Bunch of other concatenation statements to generate the html
        contentForDiv += "<li><a href=''  class='menuLink'  id='"+result[j][k]["id"]+"'>" + result[j][k]["menuName"] + "</a></li>";
        contentForDiv += "</div>";
        // At the end
        $('#menu').html(contentForDiv);
    }
</script>

在我的index.html.twig

{% extends "::base.html.twig" %}
{% block javascripts %}
{{ parent() }}
<script src="{{ asset('bundles/productorderlookup/js/ProductOrderEdit.js') }}" type="text/javascript"></script>

ProductOrderEdit.js

jQuery(document).ready(function() {
    $('a.menuLink').click(function (event) {
        event.preventDefault();
        console.log("IN THE FUNCTION");
    })
});

我生成的html看起来像这样

<ul id="menu-item">
    <li>
        <a id="1" class="menuLink" href="">Release</a>
    </li>
    <li>
        <a id="17" class="menuLink" href="">Other Pos</a>
    </li>
    <li>
        <a id="18" class="menuLink" href="">FSC Labels</a>
    </li>
</ul>

问题:点击时的链接无法正常工作。我已经尝试明确地将它包装在另一个函数中并在index.html.twig文件中调用它但它仍然无法工作。它唯一有效的时间是我在萤火虫中放置一个断点。我意识到这可能是某种竞争条件或其他一些小问题,但我无法解决它。我试过在SO上搜索各种问题,但到目前为止还没有用。可能是什么问题?

注意:我的整个页面都有多个jQuery(document).ready(function() {...});。不确定这是否重要。

1 个答案:

答案 0 :(得分:1)

这应该是非常直接的。

首先,拥有多个jQuery(document).ready(function() {...});不会影响任何代码流。如果您有很多应用程序,它可能会对您的应用程序性能产生负面影响,但功能应该保持不变。只要一个ready中的代码不依赖于另一个ready - 这只是一个简单的错误:)。

现在,回到你的问题:如果我看对了,你发出ajax调用,返回包含菜单项的json,然后转换为html并放入{{ 1}}元素。问题是页面在项目返回到您的页面之前很久就宣布了#menu事件。反过来,你的代码

ready

不应该绑定任何元素 - 那些还没有。

快速解决方法是使用委托绑定($('a.menuLink').click(function (event){ ... }); )而不是on,它不仅绑定当前存在的元素,还绑定将来创建的元素。假设click元素始终存在,您可以这样做:

#menu

这有帮助吗?