• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 200, comments - 8, trackbacks - 0, articles - 0

            jQuery之防止冒泡事件

            Posted on 2014-09-17 14:22 鑫龍 閱讀(284) 評論(0)  編輯 收藏 引用 所屬分類: 前臺

            轉(zhuǎn)自:http://www.cnblogs.com/jiqing9006/archive/2012/09/11/2679831.html

            冒泡事件就是點擊子節(jié)點,會向上觸發(fā)父節(jié)點,祖先節(jié)點的點擊事件。

            下面是html代碼部分:

            <body>
            <div id="content">
                外層div元素
                <span>內(nèi)層span元素</span>
                外層div元素
            </div>
            
            <div id="msg"></div>
            </body>

            對應(yīng)的jQuery代碼如下:

            <script type="text/javascript">
            $(function(){
                // 為span元素綁定click事件
                $('span').bind("click",function(){
                    var txt = $('#msg').html() + "<p>內(nèi)層span元素被點擊.<p/>";//獲取html信息
                    $('#msg').html(txt);// 設(shè)置html信息
                });
                // 為div元素綁定click事件
                $('#content').bind("click",function(){
                    var txt = $('#msg').html() + "<p>外層div元素被點擊.<p/>";
                    $('#msg').html(txt);
                });
                // 為body元素綁定click事件
                $("body").bind("click",function(){
                    var txt = $('#msg').html() + "<p>body元素被點擊.<p/>";
                    $('#msg').html(txt);
                });
            })
            </script>

            當(dāng)點擊span時,會觸發(fā)div與body 的點擊事件。點擊div時會觸發(fā)body的點擊事件。

            如何防止這種冒泡事件發(fā)生呢?

            修改如下:

            <script type="text/javascript">
            $(function(){
                   // 為span元素綁定click事件
                $('span').bind("click",function(event){
                    var txt = $('#msg').html() + "<p>內(nèi)層span元素被點擊.<p/>";
                    $('#msg').html(txt);
                    event.stopPropagation();    //  阻止事件冒泡
                });
                // 為div元素綁定click事件
                $('#content').bind("click",function(event){
                    var txt = $('#msg').html() + "<p>外層div元素被點擊.<p/>";
                    $('#msg').html(txt);
                    event.stopPropagation();    //  阻止事件冒泡
                });
                // 為body元素綁定click事件
                $("body").bind("click",function(){
                    var txt = $('#msg').html() + "<p>body元素被點擊.<p/>";
                    $('#msg').html(txt);
                });
            })
            </script>

            event.stopPropagation(); // 阻止事件冒泡

             

            有時候點擊提交按鈕會有一些默認(rèn)事件。比如跳轉(zhuǎn)到別的界面。但是如果沒有通過驗證的話,就不應(yīng)該跳轉(zhuǎn)。這時候可以通過設(shè)置event.preventDefault(); //阻止默認(rèn)行為 ( 表單提交 )。

            下面是案例:

            <script type="text/javascript">
            $(function(){
               $("#sub").bind("click",function(event){
                     var username = $("#username").val();  //獲取元素的值,val() 方法返回或設(shè)置被選元素的值。
                     if(username==""){     //判斷值是否為空
                         $("#msg").html("<p>文本框的值不能為空.</p>");  //提示信息
                         event.preventDefault();  //阻止默認(rèn)行為 ( 表單提交 )
                     }
               })
            })
            </script>

            html部分:

            <body>
            <form action="test.html">
            用戶名:<input type="text" id="username" />
            <br/>
            <input type="submit" value="提交" id="sub"/>
            </form>
            
            <div id="msg"></div>
            </body>

            還有一種防止默認(rèn)行為的方法就是return false。效果一樣。

            代碼如下:

            <script type="text/javascript">
            $(function(){
               $("#sub").bind("click",function(event){
                     var username = $("#username").val();  //獲取元素的值
                     if(username==""){     //判斷值是否為空
                         $("#msg").html("<p>文本框的值不能為空.</p>");  //提示信息
                         return false;
                     }
               })
            })
            </script>

            同理,上面的冒泡事件也可以通過return false來處理。

            <script type="text/javascript">
            $(function(){
                   // 為span元素綁定click事件
                $('span').bind("click",function(event){
                    var txt = $('#msg').html() + "<p>內(nèi)層span元素被點擊.<p/>";
                    $('#msg').html(txt);
                    return false;
                });
                // 為div元素綁定click事件
                $('#content').bind("click",function(event){
                    var txt = $('#msg').html() + "<p>外層div元素被點擊.<p/>";
                    $('#msg').html(txt);
                    return false;
                });
                // 為body元素綁定click事件
                $("body").bind("click",function(){
                    var txt = $('#msg').html() + "<p>body元素被點擊.<p/>";
                    $('#msg').html(txt);
                });
            })
            </script>

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            AV无码久久久久不卡网站下载| 日韩人妻无码一区二区三区久久99| 久久中文字幕人妻熟av女| 亚洲国产成人久久一区久久| 精品国产乱码久久久久软件| 国产精品久久永久免费| 精品久久综合1区2区3区激情| 国产精品久久新婚兰兰| 久久精品水蜜桃av综合天堂 | 国产麻豆精品久久一二三| 久久精品国产只有精品2020| 久久中文字幕视频、最近更新| 久久人人妻人人爽人人爽| 99久久精品免费| 久久SE精品一区二区| 国产日韩久久久精品影院首页| 亚洲国产精品无码久久久蜜芽| 国内精品伊人久久久久网站| 香蕉久久av一区二区三区 | 中文字幕无码久久精品青草 | 色欲综合久久躁天天躁蜜桃| 99久久国产热无码精品免费久久久久| 亚洲国产视频久久| 99热热久久这里只有精品68| 久久AV高清无码| 无遮挡粉嫩小泬久久久久久久| 久久亚洲AV无码西西人体| 狠狠色丁香婷婷久久综合不卡| 亚洲中文字幕无码久久2020| 中文精品99久久国产 | 久久国产香蕉一区精品| www性久久久com| 久久综合给久久狠狠97色| 2021久久精品免费观看| 四虎久久影院| 一本久久精品一区二区| 久久久久无码精品| 久久电影网| 欧美精品福利视频一区二区三区久久久精品 | 精品久久一区二区| 精品久久久久久成人AV|