亚洲免费乱码视频,日韩 欧美 国产 动漫 一区,97在线观看免费视频播国产,中文字幕亚洲图片

      1. <legend id="ppnor"></legend>

      2. 
        
        <sup id="ppnor"><input id="ppnor"></input></sup>
        <s id="ppnor"></s>

        jQuery解決input元素的blur事件和其他非表單元素的click事件沖突問題

        字號:


            這篇文章主要介紹了jQuery解決input元素的blur事件和其他非表單元素的click事件沖突問題,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
            HTML結(jié)構(gòu):很簡單,就一個input,一個div,能說明問題就OK了;
            <input type="text" value="默認(rèn)值"><br/><br/><div>搜索</div>
            想要實現(xiàn)的結(jié)果:
            1、input框獲取焦點時value為“”,失去焦點時value為“默認(rèn)值”;-----這個很好實現(xiàn);        
            2、當(dāng)在input框中輸入要搜素的內(nèi)容后,點擊div搜索,要求控制臺打印輸出要搜素的內(nèi)容(當(dāng)然每個項目的需求不同,這里只是舉個例子),而且要求點擊后不影響input的focus和blur行為;----這個才是重點
            先看看沖突沒有解決之前的效果;
            $("input").focus(function () {
            this.value = ""; }).blur(function () {
            this.value = "默認(rèn)值"; });$("div").click(function () {
            var value = $("input").val();
            console.log(value); });
            結(jié)果:在input中輸入“aaaa”,然后點擊div,控制臺輸出的卻是“默認(rèn)值”,與預(yù)想的結(jié)果不符;
            解決方法一:在blur的回調(diào)函數(shù)中加一個定時器,延遲blur回調(diào)函數(shù)的執(zhí)行時間,這樣的話雖然在點擊div的時候,input的blur行為先被觸發(fā),但是由于加了定時器延遲,所以得等到div的click回調(diào)執(zhí)行完成后才能執(zhí)行input的blur行為的回調(diào);
            $("input").focus(function () {
            this.value = "";}).blur(function () {
            var self=this;
            setTimeout(function(){
            self.value = "默認(rèn)值";
            },300)}); $("div").click(function () {//這部分不變
            var value = $("input").val();
            console.log(value); });
            結(jié)果:在input中輸入“aaaa”,然后點擊div,控制臺輸出的卻是“aaaa”,符合預(yù)想的結(jié)果;
            解決方法二:將div的click事件改成mousedown事件,因為mousedown行為是鼠標(biāo)點下去的時候就被觸發(fā),而click行為是鼠標(biāo)點下去再抬起的時候才被觸發(fā);
            $("input").focus(function () {//這部分不變
            this.value = "";}).blur(function () {
            this.value = "默認(rèn)值";}); $("div").mousedown(function () {
            var value = $("input").val();
            console.log(value); });
            結(jié)果:在input中輸入“aaaa”,然后點擊div,控制臺輸出的卻是“aaaa”,符合預(yù)想的結(jié)果;
            以上所述是小編給大家介紹的jQuery解決input元素的blur事件和其他非表單元素的click事件沖突問題,希望對大家有所幫助