动态加载的元素,alert出不来 ,模拟app 长按后触发事件

模拟app 长按后触发事件

$.fn.longPress = function(fn) {

        var timeout = undefined;
        var $this = this;
        for(var i = 0;i<$this.length;i++){
            $this[i].addEventListener('touchstart', function(event) {
                timeout = setTimeout(fn, 800);
            }, false);
            $this[i].addEventListener('touchend', function(event) {
                clearTimeout(timeout);
            }, false);
        }
    };
    
    //cmt01动态添加的元素
    $('.cmt01').each(function(e){
        //var _this = $(this);
        $(this).longPress(function(){
            alert(1)
        });
    })
阅读 1.9k
1 个回答

最简单的解释就是:

你给元素cmt01绑定事件的时候,后续加载的元素并不存在,所以无法触发。

解决办法:事件委托。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题