使用jQuery模拟鼠标点击a标签事件
2015-09-28 10:55
801 查看
[文章作者:磨延城 转载请注明原文出处: http://mo2g.com/view/42/ ]
我尝试过多次用jQuery模拟用户点击a标签的功能,但都没有成功,并且困扰了很久。前段时间的一次发呆,冒出了新的想法,于是就动手进行了测试。
先看下边的代码:
上边的代码确实已经触发了点击A标签事件,但大家一定也会有疑问,为什么点击了A标签,却不触发A标签的跳转事件?
一开始还以为是浏览器做了相应的安全措施,屏蔽了JS对A标签的操作,后来发现,并不是这样的,接下来就说说其中的原委。
在开始解释前,我先抛出一个问题。在我们点击“A标签”的时候,究竟是点击了什么才发生的跳转?
1)点击的是“A标签”本身?
2)点击的是“A标签”中显示的文字?
说到这里,大家应该明白了,我们上边的代码已经证实了点击A标签本身,并不会触发跳转到指定链接的事件,就是说,我们平时都是点击的A标签中的文字了?
既然有了头绪,那么就来动手试试。
这下效果出来了,事实证明了上述的推断是正确的,所以要想用JS模拟点击A标签事件,就得先往A标签中的文字添加能被JS捕获的元素,然后再用JS模拟点击该元素即可。
2015年6月15日,根据@bl的补充,我们可以使用更加简单的方式实现同样的功能,代码如下:
打印$("a")[0],得到的是http://www.mo2g.com,但实际上$("a")[0]是一个object对象,或许说是DOM对象更贴切一些。经过测试发现,其实原生的js就已经实现了类似的点击a标签的功能。原生js写法类似如下:
只要获取到A标签的DOM对象,就能使用click()函数激活点击事件了。
我尝试过多次用jQuery模拟用户点击a标签的功能,但都没有成功,并且困扰了很久。前段时间的一次发呆,冒出了新的想法,于是就动手进行了测试。
先看下边的代码:
一开始还以为是浏览器做了相应的安全措施,屏蔽了JS对A标签的操作,后来发现,并不是这样的,接下来就说说其中的原委。
在开始解释前,我先抛出一个问题。在我们点击“A标签”的时候,究竟是点击了什么才发生的跳转?
1)点击的是“A标签”本身?
2)点击的是“A标签”中显示的文字?
说到这里,大家应该明白了,我们上边的代码已经证实了点击A标签本身,并不会触发跳转到指定链接的事件,就是说,我们平时都是点击的A标签中的文字了?
既然有了头绪,那么就来动手试试。
2015年6月15日,根据@bl的补充,我们可以使用更加简单的方式实现同样的功能,代码如下:
相关文章推荐
- JQuery Ajax调用asp.net后台方法
- jquery中^是什么意思
- MVC笔记2:mvc+jquery.validate.js 进行前端验证
- jQuery、layer实现弹出层的打开、关闭
- jQuery源码分析之深入理解jQuery.data,jQuery._data以及data实例函数十八问
- jquery 输入框自动提示
- jquery js 传递对象 数组
- jquery 页面校验器的使用
- jquery validate异步验证时多参数传递
- jQuery实现长按按钮触发事件的方法
- jQueryEasyUI Messager基本使用
- struts2+jquery 实现ajax无刷新更新数据
- jQuery源码分析之proxy函数
- jQuery源码分析之jQuery.makeArray函数
- 源码分析之jQuery.merge函数
- 【jQuery】ajax提交xml
- jQuery.extend函数源码详解
- jQuery源码阅读之jQuery.Callbacks ()
- JQuery实现左右滚动菜单特效
- jQuery EasyUI Dialog拖不下来如何解决