为什么这个 jquery 函数在 iPhone 操作系统上不起作用?
以下 jquery 在大多数桌面浏览器中工作正常,但在 android 和 iphone 浏览器上失败:
$('#submit_event').live('click', function() {
if ($("#event_name").attr("value") != "" && $("#event_details").attr("value") != ""){
sendEvent($("#event_name").attr("value"), $("#event_details").attr("value"));
$('#response_container').append("<div class='event_title'>"+$("#event_name").attr("value")+"</div><div class='event_details'>"+$("#event_details").attr("value")+"<div class='comment'>Comment</div><textarea class='comment_area'></textarea><div id='post_comment'>Post</div></div>");
}
});
#submit_event 只是 div 的 ID。单击后,它会在桌面浏览器上运行该功能,但不会在 Android 或 iPhone 上运行。
问候,
泰勒
The following jquery works fine in most desktop browsers, but fails on android and iphone browsers:
$('#submit_event').live('click', function() {
if ($("#event_name").attr("value") != "" && $("#event_details").attr("value") != ""){
sendEvent($("#event_name").attr("value"), $("#event_details").attr("value"));
$('#response_container').append("<div class='event_title'>"+$("#event_name").attr("value")+"</div><div class='event_details'>"+$("#event_details").attr("value")+"<div class='comment'>Comment</div><textarea class='comment_area'></textarea><div id='post_comment'>Post</div></div>");
}
});
The #submit_event is just the ID to a div. When clicked, it runs the function on desktop browsers, but not android or iphone.
regards,
taylor
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
您可以尝试更有效的代码:
You could try more efficient code:
好吧,我找到了答案,
这只是移动游猎中的一个错误。
您需要做的就是将 onclick='' 添加到您绑定 live 函数的任何元素,它就会起作用。
Ok I found my answer,
It's just a bug in mobile safari.
All you need to do is add onclick='' to any element that you bind the live function to and it will work.
是的,.live 事件不适用于 td 等元素。它将与锚标记、按钮等 html 元素一起使用。因此,如果您想使用 jQuery 的 .live 事件应用 click 事件,您需要首先在 td 元素上使用 jquery .attr 方法添加 onclick="" 属性,然后应用。将事件与 td 元素绑定的实时事件。有关更多详细信息,请访问以下博客
http://skillativity .blogspot.com/2010/11/workaround-for-jquery-live-event.html
Yes .live event will not work with element like td. It will work with html element like anchor tag, button etc. So if you want to apply click event using .live event of jQuery you need to first add onclick="" attribute using jquery .attr method on your td element and then apply .live event to bind event with your td element. For more detail please visit on below blog
http://skillfulness.blogspot.com/2010/11/workaround-for-jquery-live-event.html
如果你也在使用jquery mobile,你可能想尝试一下
If you are using jquery mobile too, you might want to try