我在一个按钮上有一个onClick事件,它是使用从服务器返回的数据(通过Ajax)创建的。我的代码概要如下:
$(document).on('pageinit', function() {
$.ajax({
url: '/',
dataType: 'json',
type: 'POST',
contentType: 'application/x-www-form-urlencoded',
data: textInput,
success: function (response) {
if(response.error_code!=null){
alert(response.user_message);
}
else {
//code to generate button with id tag `cvResults`
$('#cvResults').click(function(e) {
// some code here, redirects to another mobile page
}
},//then remainder of ajax function我最初尝试将onClick函数放在Ajax调用之外(但放在pageinit内)。这不会触发,因为页面将在没有任何#cvResults标记的情况下启动,因此不会加载函数。
我现在有一个不同的问题。当您单击此按钮并转到另一个页面时,如果您随后按下back并尝试再次单击该按钮,则不会触发事件。这是有意义的,因为Ajax还没有响应。
如何才能同时满足这两种情况,并在#cvResults标记出现时永久侦听onClick事件?
发布于 2015-03-12 16:25:03
尝试使用此方法为动态创建的元素绑定任何单击事件。
$('document').on('click','#cvResults',function(){
// your code.
})由于您的页面初始化时没有此元素,因此如果您以常规方式执行此操作,事件将不会绑定。
https://stackoverflow.com/questions/29004900
复制相似问题