jquery如何阻止子元素相應mouseout事件

来源:http://www.cnblogs.com/zhadanren/archive/2016/01/11/5122517.html
-Advertisement-
Play Games

jquery如何阻止子元素相應mouseout事件:mouseout有一個特點,當滑鼠移入子元素的時候,也會觸發此事件,但是在實際應用中這個特點往往不是我們想要的,下麵就通過代碼實例介紹一下如何實現此效果,代碼實例如下:螞蟻部落 以上代碼實現了我們的要求,當滑鼠指針移入子div的時候,不會觸發事件....


jquery如何阻止子元素相應mouseout事件:
mouseout有一個特點,當滑鼠移入子元素的時候,也會觸發此事件,但是在實際應用中這個特點往往不是我們想要的,下麵就通過代碼實例介紹一下如何實現此效果,代碼實例如下:

 

<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
#father
{
  width:100px;
  height:100px;
  background:red;
}
#inner
{
  width:50px;
  height:50px;
  background:green;
}
</style>
<script type="text/javascript" src="mytest/jQuery/jquery-1.8.3.js"></script>
<script type="text/javascript"> 
$(document).ready(function(){
  $("#father").mouseout(function(e){ 
    evt = window.event||e; 
    var obj=evt.toElement||evt.relatedTarget; 
    var pa=this; 
    if(pa.contains(obj)) return false; 
    $(this).hide(); 
  });   
})
</script>
</head>
<body>
<div id="father">
  <div id="inner"></div>
</div>
</body>
</html>

 

以上代碼實現了我們的要求,當滑鼠指針移入子div的時候,不會觸發事件,但是當滑鼠移出父div的時候會觸發事件,下麵接掃一下實現此效果的過程。
一.實現原理:
原理非常的簡單,就是判斷當滑鼠指針移動的時候,判斷與事件的目標節點相關的節點是否是子元素,如果是子元素,則不觸發事件,如果不是子元素則觸發事件。
二.相關閱讀:
1.mouseout事件可以參閱jQuery的mouseout事件一章節。 
2.evt = window.event||e可以參閱var ev=window.event||ev的作用是什麼一章節。 
3.toElement屬性可以參閱javascript的toElement事件屬性一章節。 
4.relatedTarget屬性可以參閱javascript的relatedTarget事件屬性一章節。 
5.this可以參閱javascript的this用法詳解一章節。 
6.contains()函數可以參閱jQuery.contains()方法一章節。
7.hide()函數可以參閱jQuery的hide()方法一章節。

原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=11377

更多內容可以參閱:http://www.softwhy.com/jquery/

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如何禁止使用框架iframe引用網站頁面:很多網站喜歡引用外站的頁面,有的可能為了方便,有的可能喜歡對方網站,目的可能是多種多樣的,但是有些站長並不像自己的網頁被別人引用,下麵就簡單介紹一下如何實現此功能。方法一:if(top.location!==self.location){ top.loca....
  • css設置span元素的尺寸:在預設狀態下是無法設置span元素的尺寸的,只能夠根據內容的尺寸自適應,也就是說給span元素設置width和height屬性預設條件是無效的。之所以會出現這種情況是因為span元素是內聯元素,內聯元素無法設置尺寸的,只要設置為塊級或者內聯塊級元素即可。代碼實例如下: ...
  • 如何利用jquery.1.9版本判斷瀏覽器的版本類型:在jquery.1.9以前的版本,可以使用$.browser很輕鬆的判斷瀏覽器的類型和版本,但是在1.9中和以後的版本中,$.browser已經被刪除,下麵就介紹一下如何實現此功能,希望能夠給需要的朋友帶來幫助。一.自定義代碼:$.browser...
  • 點擊文本框清除預設文本離開再恢復:很多網站的需要填寫的文本框在預設狀態下都會給出一個預設的提示語言,當滑鼠點擊此文本框的時候能夠將裡面的預設文本清除,當刪除輸入的文本且焦點離開文本框的時候再將預設的文本寫入文本框。代碼如下:點擊文本框清除預設值-螞蟻部落以上代碼實現了我們的要求,當點擊文本框的時候能...
  • 與換行相關的css屬性簡單介紹:在css佈局中可能需要人為的進行操作是否換行,如何換行,本章節就就做一下簡單介紹。一.word-break屬性:此屬性用來設定文本如何進行換行。語法結構:word-break:normal | break-all | keep-all參數解析:1.normal:預設值...
  • 滑鼠懸浮於鏈接之上出現文字說明效果:對於超鏈接標簽,有一個title屬性,當滑鼠表懸浮於鏈接之上時候,就會顯示title的屬性值,雖然在一定程度上滿足了我們的需要,但是美觀度卻似差強人意,同時無法修改它的樣式,下麵就來介紹一下如何利用jquery模擬實現此功能。代碼如下:螞蟻部落 螞蟻部落 ...
  • 網頁右下角彈出廣告信息框實例代碼:右下角彈出視窗效果是常見的彈出視窗效果之一,比如可以作為廣告視窗,也可以作為網站的一些公告或者通知,非常的實用,下麵就通過實例簡單介紹一下如何實現此功能,代碼如下:網頁右下角的信息框-螞蟻部落 3秒後會在右下角自動彈出視窗,如果沒有彈出請點擊這個按鈕 您有新的短.....
  • div垂直水平居中代碼實例:本章節分享一段代碼實例,它演示瞭如何讓div實現全屏垂直水平居中和指定元素的內容垂直水平居中。代碼實例如下:螞蟻部落 以上代碼實現了我們的要求,能夠實現居中效果,代碼比較簡單,就是基本的邏輯問題。原文地址是:http://www.softwhy.com/forum.ph....
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...