我正在使用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() {...});
。不确定这是否重要。
答案 0 :(得分:1)
这应该是非常直接的。
首先,拥有多个jQuery(document).ready(function() {...});
不会影响任何代码流。如果您有很多应用程序,它可能会对您的应用程序性能产生负面影响,但功能应该保持不变。只要一个ready
中的代码不依赖于另一个ready
- 这只是一个简单的错误:)。
现在,回到你的问题:如果我看对了,你发出ajax
调用,返回包含菜单项的json
,然后转换为html
并放入{{ 1}}元素。问题是页面在项目返回到您的页面之前很久就宣布了#menu
事件。反过来,你的代码
ready
不应该绑定任何元素 - 那些还没有。
快速解决方法是使用委托绑定($('a.menuLink').click(function (event){ ... });
)而不是on
,它不仅绑定当前存在的元素,还绑定将来创建的元素。假设click
元素始终存在,您可以这样做:
#menu
这有帮助吗?