在JS中a标签加⼊单击事件屏蔽href跳转页⾯
我们常⽤的在a标签中有点击事件:
1.href标签怎么用
a href="JavaScript:js_method();"
这是我们平台上常⽤的⽅法,但是这种⽅法在传递this等参数的时候很容易出问题,⽽且javascript:协议作为a的href属性的时候不仅会导致不必要的触发beforeunload事件,在IE⾥⾯更会使gif动画图⽚停⽌播放。W3C标准不推荐在href⾥⾯执⾏javascript语句
2.
a href="javascript:void(0);" onclick="js_method()"
这种⽅法是很多⽹站最常⽤的⽅法,也是最周全的⽅法,onclick⽅法负责执⾏js函数,⽽void是⼀个操作符,void(0)返回undefined,地址不发⽣跳转。⽽且这种⽅法不会像第⼀种⽅法⼀样直接将js⽅法暴露在浏览器的状态栏。
3.
a href="javascript:;" onclick="js_method()"
这种⽅法跟跟2种类似,区别只是执⾏了⼀条空的js代码。
4.
a href="#" onclick="js_method()"
这种⽅法也是⽹上很常见的代码,#是标签内置的⼀个⽅法,代表top的作⽤。所以⽤这种⽅法点击后⽹页后返回到页⾯的最顶端。
5.
a href="#" onclick="js_method();return false;"
这种⽅法点击执⾏了js函数后return false,页⾯不发⽣跳转,执⾏后还是在页⾯的当前位置。
我看了下taobao的主页,他们采⽤的是第2种⽅法,⽽alibaba的主页是采⽤的第1种⽅法,和我们的区别是每个href⾥的javascript⽅法都⽤try、catch包围。
综合上述,在a中调⽤js函数最适当的⽅法推荐使⽤:
a href="javascript:void(0);" onclick="js_method()"
a href="javascript:;" onclick="js_method()"
a href="#" onclick="js_method();return false;"
解释:
javascript:是伪协议,表⽰url的内容通过javascript执⾏。 void(0)表⽰不作任何操作,这样会防⽌链接跳转到其他页⾯。这么做往往是为了保留链接的样式,但不让链接执⾏实际操作,具体的操作交给链接的onclick事件处理.
以上所述是⼩编给⼤家介绍的在JS中a标签加⼊单击事件屏蔽href跳转页⾯,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。