jQuery的hover事件只是針對單個HTML元素,例如:
$('#login').hover(fun2, fun2);
當滑鼠進入#login元素時呼叫fun1函數,離開時則呼叫fun2函數,這種API已能滿足絕大部分需求。
不過,有些時候我們希望當滑鼠進入兩個或多個元素時觸發fun1,離開他們時觸發fun2,而在這些元素間移動滑鼠並不觸發任何事件。例如兩個元素緊鄰的HTML元素,如下圖:

當滑鼠進入二者的區域時觸發fun1,離開時觸發fun2。你或許會想到用下面的方式
$(' trigger, #drop'),hover(fun1, fun2);
這種方式並不能滿足我們的需求,因為從#trigger進入#drop時會觸發fun2和fun1。要解決這個問題,比較簡單的方式是改變HTML結構,實作方式如下:
$('#container').hover(fun1, fun2);
這樣透過在父元素上綁定hover事件來實現此功能。
2.範例研究
下圖為常見的下拉式選單簡單化圖,HTML結構如下:

複製程式碼
程式碼如下:
ul id="#nav">
下拉選單
- 下拉項目1
- 下拉項目2
- 下拉項3
複製代碼
複製程式碼
複製程式碼
程式碼如下:
複製代碼
代碼如下:
- 下拉項目1
- 下拉項目2
- 下拉項3
依序引入JS檔案
程式碼如下:
複製程式碼
程式碼如下:
程式碼如下:
$. 🎜>'#trigger',
'#drop',
function(trg, drop){
},
function(trg, drop);
},
function(trg, drop ){
複製程式碼
程式碼如下:/**
* 作者:http://rainman.cnblogs.com/
* 日期:2014-06-06
* 依賴:jQuery
*/
$.mixhover = function() {
// 整理參數$.mixhover($e1, $e2, handleIn, handleOut)
var parms;
var length = arguments.length;
var handleIn = arguments[length - 2];
var handleOut = arguments[length - 1];
if ($.isFunction(handleIn) & &t.Function & G. )) {
parms = Array.prototype.slice.call(arguments, 0, length - 2);
} else if ($.isFunction(handleOut)) {
parms = Array.prototype.slice .call(arguments, 0, length - 1);
handleIn = arguments[length - 1];
handleOut = null;
} else {
parms = arguments;
} else {
parms = arguments; ;
handleOut = null;
}
// 整理參數使得elements依序對應
var elems = [];
for (var i = 0, len = parms.length ; i elems[i] = [];
var p = parms[i];
if (p.constructor === String) {
p = $ (p);
}
if (p.constructor === $ || p.constructor === Array) {
for (var j = 0, size = p.length; j elems[i].push(p[j]);
}
} else {
elems[i].push(p);
}
}
// 綁定Hover事件
for (var i = 0, len = elems[0].length; i var arr = [];
for (var j = 0, size = elems.length; j arr.push(elems[j][i]);
}
$._mixhover(arr, handleIn, handleOut);
}
};
$._mixhover = function(elems, handleIn, handleOut) {
var isIn = false, timer;
$(elems).hover( function() {
window.clearTimeout(timer);
if (isIn === false) {
handleIn && handleIn.apply(elems, elems);
isIn = true
;
; }
},

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr

Node.js擅長於高效I/O,這在很大程度上要歸功於流。 流媒體匯總處理數據,避免內存過載 - 大型文件,網絡任務和實時應用程序的理想。將流與打字稿的類型安全結合起來創建POWE

Python和JavaScript在性能和效率方面的差異主要體現在:1)Python作為解釋型語言,運行速度較慢,但開發效率高,適合快速原型開發;2)JavaScript在瀏覽器中受限於單線程,但在Node.js中可利用多線程和異步I/O提升性能,兩者在實際項目中各有優勢。

JavaScript起源於1995年,由布蘭登·艾克創造,實現語言為C語言。 1.C語言為JavaScript提供了高性能和系統級編程能力。 2.JavaScript的內存管理和性能優化依賴於C語言。 3.C語言的跨平台特性幫助JavaScript在不同操作系統上高效運行。

JavaScript在瀏覽器和Node.js環境中運行,依賴JavaScript引擎解析和執行代碼。 1)解析階段生成抽象語法樹(AST);2)編譯階段將AST轉換為字節碼或機器碼;3)執行階段執行編譯後的代碼。

Python和JavaScript的未來趨勢包括:1.Python將鞏固在科學計算和AI領域的地位,2.JavaScript將推動Web技術發展,3.跨平台開發將成為熱門,4.性能優化將是重點。兩者都將繼續在各自領域擴展應用場景,並在性能上有更多突破。

Python和JavaScript在開發環境上的選擇都很重要。 1)Python的開發環境包括PyCharm、JupyterNotebook和Anaconda,適合數據科學和快速原型開發。 2)JavaScript的開發環境包括Node.js、VSCode和Webpack,適用於前端和後端開發。根據項目需求選擇合適的工具可以提高開發效率和項目成功率。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Atom編輯器mac版下載
最受歡迎的的開源編輯器