成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導(dǎo)航首頁 ? 技術(shù)教程 ? 深入理解jQuery中的事件冒泡
全站頭部文字 我要出現(xiàn)在這里
深入理解jQuery中的事件冒泡 628 2024-03-03   

1.什么是冒泡

eg:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  <title>事件冒泡</title>
  <script src="http://www.gimoo.net/js/jQuery1.11.1.js"></script>
  <script type="text/javascript">
    $(function () {
      //為span元素綁定click事件
      $('span').bind('click', function () {
        var txt = $('#msg').html() + '<p>內(nèi)層span元素被點擊</p>';
        $('#msg').html(txt);
        
      });
      //為span元素綁定click事件
      $('#content').bind('click', function () {
        var txt = $('#msg').html() + '<p>外層div元素被點擊</p>';
        $('#msg').html(txt);
      });
      //為span元素綁定click事件
      $('body').bind('click', function () {
        var txt = $('#msg').html() + '<p>body元素被點擊</p>';
        $('#msg').html(txt);
      });
    });
    
  </script>
</head>
<body>
  <div id="content">
    外層div元素
    <span>內(nèi)層span元素</span>
  </div>
  <div id="msg"></div>
</body>
</html>

當(dāng)你單擊‘內(nèi)層span元素'時,即觸發(fā)<span>元素的click事件時,會輸出3條記錄

即:

內(nèi)層span元素被點擊

外層div元素被點擊

body元素被點擊

這就是事件冒泡引起的。

查看圖片

2.事件冒泡引發(fā)的問題

01.事件對象

在程序中使用事件對象,只需要為函數(shù)添加一個參數(shù),jQuery代碼如下:

$('element').bind('click',function(event){ //event:事件對象

});

02.停止事件冒泡

在jQuery中提供了stopPropagation()方法來停止事件冒泡

以span元素綁定click事件為例:

//為span元素綁定click事件
      $('span').bind('click', function (event) { //event:事件對象
        var txt = $('#msg').html() + '<p>內(nèi)層span元素被點擊</p>';
        $('#msg').html(txt);
        event.stopPropagation(); //停止事件冒泡
      });

當(dāng)你單擊‘內(nèi)層span元素'時,即觸發(fā)<span>元素的click事件時,這時只會輸出1條記錄

即:

內(nèi)層span元素被點擊

這樣就解決了冒泡問題

03.阻止默認行為

網(wǎng)頁中的元素有自己默認的行為,例如,單擊超鏈接后會跳轉(zhuǎn),單擊‘提交'表單會提交,有時需要阻止元素的默認行為

在jQuery中,提供了preventDefault()方法來阻止元素的默認行為。

eg:以輸入提交為例

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  <title></title>
  <script src="http://www.gimoo.net/js/jQuery1.11.1.js"></script>
  <script type="text/javascript">
    $(function () {
      $('#sub').bind('click', function (event) {
        var username = $('#username').val(); //獲取元素的值
        if (username == "") {  //判斷是否為空
          alert('文本框的值不能為空'); //提示信息
          event.preventDefault(); //阻止默認行為(表單提交)
        }
      });
    });
  </script>
</head>
<body>
  <form action="/">
    用戶名:<input type="text" id="username" />
    <input type="submit" value="提交" id="sub" />
  </form>  
</body>
</html>

假如你不輸入內(nèi)容,這樣就可以阻止默認行為(表單提交)

總結(jié):如果想同時對事件停止冒泡和默認行為,可以在事件處理函數(shù)中返回false。這是對在事件對象上同時調(diào)用stopPropagation()方法和preventDefault()方法的一種簡寫方式。

在上面表單的例子中,可以把

event.preventDefault(); //阻止默認行為(表單提交)

改寫為:return false;

也可以把事件冒泡中的event.stopPropagation(); //停止事件冒泡

改寫為:return false;

04.事件捕獲

查看圖片

05.事件對象的屬性

查看圖片

事件對象的屬性 詳情請參考:http://www.w3school.com.cn/jsref/dom_obj_event.asp

以上這篇深入理解jQuery中的事件冒泡就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持綠夏網(wǎng)。



主站蜘蛛池模板: 美女自拍偷拍| 影子是我的好朋友仿句怎么写| 我是特种兵剧情介绍| 生物选择性必修三| 美媚直播| 二哈和他的白猫师尊车子图片| 自拍成人| 第一财经在线直播电视| 李顺大造屋| 怎么剪福字简单方法视频| 十一个月宝宝发育标准| 三大| 唐人街探案免费观看完整版| 张钰凰| 橘子洲旅游攻略| 香港之夜在线观看免费版香港电影| 宁波电视台| 天下免费大全正版资料| 飞头魔女电影完整版免费观看| 杏色xs| 熊出没之雪岭熊风 2015 张伟| 香谱72图解详细解释大全| 胡家玮| 藏身之所| 神笔马良动画片| 丰满美女| 电影《男宠》在线观看| 国家地理频道| 浪荡子的旅程电影| 中国少先队队歌歌词| 情事2018| 演员王磊| 13名妓| 韩国xxxxxxxxxxxx| 赵立军| 精灵使的剑舞无删减版在线观看| city of stars歌词| 可隆衣服属于什么档次| 百岁宫简介| 宋晓飞| 画江湖之不良人第一季动漫免费观看|

!!!站長長期在線接!!!

網(wǎng)站、小程序:定制開發(fā)/二次開發(fā)/仿制開發(fā)等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103