这两个事件很常见。
了解这两个事件的区别,但是实际并没有使用到这两个事件的区别去做一些操作。
通常使用onclick的时候也可以使用onmousedown,使用onclick的时候更多一些。
今天碰到了非使用onmousedown不可的时候,故特此记录。

先说一下区别:onclick是在鼠标点击弹起之后触发的事件。onmousedown是在鼠标按下之后触发的事件。
简单的说onclick = onmousedown onmouseup;
如果在某个地方按下鼠标后移开鼠标在另外一个地方松开鼠标会触发onmousedown事件,但是onclick事件却不会被触发。
我们今天要实现的功能是点击a标签,切换到另外一个页面,在原页面关闭之前需要触发一个函数。不是windowunload。
之前使用的是onclick事件,IE中测试无问题,但是在FF中测试发现,在页面被销毁之前还没有来得及执行这个函数。
如果使用onmousedown事件,虽然也没有办法保证该函数一定被执行,但是为该函数的执行争取了一定的时间,因为跳转是在鼠标弹起之后执行的。

解决办法一:onclick="return test()",当且仅当当该函数返回true之后才执行跳转。这样导致了一个新的问题。如果我们在test函数中执行了多线程程序或者新开线程的程序后,会先返回true,跳转,新开的线程就没有被执行。如下面的函数:

function test() 
{ 
(new Image()).src="1.html"; 
window.open("1.html","_new"); 
//alert("ok"); 
return true; 
}

我在1.html文件中设置了<body onload="javascript:alert('ok')">,当1.html并没有被完全渲染结束时,跳转已经执行了。new image函数也没有保证已经被执行了。
在使用单一线程执行函数时,可使用return test()这种方法。

解决办法二:估计一下test函数的多线程函数的最长执行速度,加入执行时间为100.不在a标签中使用跳转。在test函数中使用setTimeout(location.href="1.html",100)来执行跳转。

js函数中onmousedown和onclick的区别和联系探讨的更多相关文章

  1. swift 中如何定义接口

    匿名接口,swift比java更随意,连接口名字也不用,直接定义直接传递,一门牛哄哄的语言

  2. 添加按钮(swift)

    添加按钮1.定义button2.使用

  3. 《从零开始学Swift》学习笔记Day 65――Cocoa Touch设计模式及应用之选择器

    在C语言在提供一种函数指针技术,Objective-C和Swift语言都提供选择器类型,它是C语言函数指针的面向对象替代技术。选择器在Cocoa和CocoaTouch中的目标动作、通知和委托等模式中方法的调用实现的关键。穷其根本是源自于Objective-C多重参数方法命名规律。

  4. android – onClick在转换后不起作用

    我正在尝试学习简单的TransitionManager工作,但我有点卡住……我的目标是通过图像点击在两个场景之间进行切换.但在第一次图像点击和第一次场景变换后,我无法捕捉图像点击…这是我的片段代码:片段xml:scene1xml:scene2xml:你知道我哪里错了吗?解决方法您需要再次设置onClickListeners才能使其正常工作.在onCreateView中,您可以直接调用setListeners方法.

  5. android – 在尝试将一些代码放入builder.setPositiveButton的onClick()方法时获取’无法解析方法’addOnCompletionListener()’…’

    我正在尝试在AlertDialog.Builder的builder.setPositiveButton方法中放置一些代码.问题是我收到以下错误:无法解析方法’addOnCompletionListener(匿名android.content.DialogInterface.OnClickListener,匿名com.google.android.gms.tasks.OnCompletionList

  6. android – 如果使用主题,则无法在活动类TintContextWrapper中为onClick找到onClick(View)方法

    我从运行4.2.2的设备中得到了这个问题…

  7. android – listView onclick转到一个新活动

    我有一个listview,我想从我按下的每个列表项目去一个新的活动.这是我的代码..}解决方法在该方法中使用switch语句:将类名更改为每个Activity需要的名称.

  8. 使用Android接收onTouch和onClick事件

    我有一个视图需要处理onTouch手势和onClick事件.实现这个目标的正确方法是什么?

  9. android – 处理具有自己意图的链接onClick事件

    解决方法卡洛斯的回答很有效,但我也想用ACTION_VIEW作为我想要开始的外部意图.幸运的是,Linkify确实添加了应用程序ID作为意图的额外内容,我的其他意图不添加,所以我使用以下逻辑来确保我正确处理Linkify意图:

  10. Android:消息意图

    我是android的初学者.我需要知道有没有打开CreateMessage窗口的意图.我试过这个代码–但它提出了Gmail,Email&消息我只需要提出消息.在我的应用程序中,当我按下按钮时,我将整合它.有谁知道这个?引导我.解决方法您可以在您的xml文件中添加和活动:

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部