美文网首页Front End
[jQuery Mobile] jQuery Mobile中su

[jQuery Mobile] jQuery Mobile中su

作者: 何幻 | 来源:发表于2016-03-02 19:56 被阅读348次

    (1)现象:
    引用jQuery Mobile,为页面中的一个button绑定事件,使用submit按钮提交表单。
    结果,页面“看起来”像是刷新了,但是刷新后button按钮的事件丢失了。

    例如:

    <input type="submit" id="submit1" value="submit" />
    <input type="button" id="button1" value="button" />
    <script>
        $('#button1').click(function () {
            alert();
        });
    </script>
    

    (2)原因
    查看网页的network发现,页面并没有刷新,而是由jQuery Mobile接管了表单的提交事件,用ajax来模拟进行了表单提交。
    jQuery Moile取得ajax结果之后,删除并重新创建了原来的DOM,所以原来DOM之上的事件就丢失了。

    (3)解决方法
    使用form表单元素的原生submit方法来提交表单,
    并且在submit按钮的click事件中返回false。

    $('#submit1').click(function(){
        $('#form1')[0].submit();
        return false;
    });
    

    相关文章

      网友评论

        本文标题:[jQuery Mobile] jQuery Mobile中su

        本文链接:https://www.haomeiwen.com/subject/kvpnkttx.html