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

发布于 2022-09-04 13:14:20 字数 644 浏览 25 评论 0

模拟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)
        });
    })

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

尐籹人 2022-09-11 13:14:20

最简单的解释就是:

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

解决办法:事件委托。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文