开发者

Why doesn't this jquery function work on iPhone OS?

开发者 https://www.devze.com 2023-03-02 18:49 出处:网络
The following jquery works fine in most desktop browsers, but fails on android and iphone browsers: $(\'#submit_event\').live(\'click\', function() {

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


You could try more efficient code:

$('#submit_event').live('click', function() {

    var eName = $("#event_name").attr('value');
    var eDetails = $("#event_details").attr('value');

    if (eName && eDetails) {
        sendEvent(eName, eDetails);
        $('#response_container').append("<div class='event_title'>" +
            eName + 
            "</div><div class='event_details'>" +
            eDetails + 
            "..."
        );
    }
});


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.


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


If you are using jquery mobile too, you might want to try

$('#submit_event').live('tap', function() {}
0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号