javascript - zepto tap方法中设置event.preventDefault 不起作用?

查看:155
本文介绍了javascript - zepto tap方法中设置event.preventDefault 不起作用?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

执行完方法之后,a标签还是跳转了。
我该如何在通过js控制。(不在html中控制)

$('.size-list').on('tap', 'li a', function(event) {
            event.preventDefault();
            $(this).addClass('active');
        });

解决方案

阻止默认行为,不要作用在tap事件上,tap事件底层是touch相关的事件。
应该阻止在click上,a跳转的行为应该是在click上的,因为以前是没有touch事件的,不排除以后或者有的浏览器a跳转的处理的底层是在touch事件上的(个人觉得可能性不大,跳转操作是有延时的)。

你阻止默认行为在touch事件上,自然而然是阻止不了a跳转相关的默认行为的。

所以,你应该调整代码为:

$('.size-list').on('click', 'li a', function(event) {
    event.preventDefault();
    $(this).addClass('active');
});

多说一句,对于移动端,因为推荐使用touch相关的事件,而不是click事件。对于这种连接处理,我一般不通过href来处理,而是自定义data-href的方式来处理(前提是,需要对操作进行处理的情况哈)。

这篇关于javascript - zepto tap方法中设置event.preventDefault 不起作用?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆