熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> Java編程 >> JSP教程 >> 正文

js函數中onmousedown和onclick的區別

2022-06-13   來源: JSP教程 

  這兩個事件很常見

  了解這兩個事件的區別但是實際並沒有使用到這兩個事件的區別去做一些操作

  通常使用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="html";

  windowopen("html""_new");

  //alert("ok");

  return true;

  }

  我在html文件中設置了html並沒有被完全渲染結束時跳轉已經執行了new image函數也沒有保證已經被執行了

  在使用單一線程執行函數時可使用return test()這種方法

  解決辦法二估計一下test函數的多線程函數的最長執行速度加入執行時間為不在a標簽中使用跳轉在test函數中使用setTimeout(locationhref="html")來執行跳轉


From:http://tw.wingwit.com/Article/program/Java/JSP/201311/20073.html
    推薦文章
    Copyright © 2005-2022 電腦知識網 Computer Knowledge   All rights reserved.