jQuery解決input元素的blur事件和其他非表單元素的click事件沖突問(wèn)題
HTML結(jié)構(gòu):很簡(jiǎn)單,就一個(gè)input,一個(gè)div,能說(shuō)明問(wèn)題就OK了;
<input type="text" value="默認(rèn)值"><br/><br/><div>搜索</div>
想要實(shí)現(xiàn)的結(jié)果:
1、input框獲取焦點(diǎn)時(shí)value為“”,失去焦點(diǎn)時(shí)value為“默認(rèn)值”;-----這個(gè)很好實(shí)現(xiàn);
2、當(dāng)在input框中輸入要搜素的內(nèi)容后,點(diǎn)擊div搜索,要求控制臺(tái)打印輸出要搜素的內(nèi)容(當(dāng)然每個(gè)項(xiàng)目的需求不同,這里只是舉個(gè)例子),而且要求點(diǎn)擊后不影響input的focus和blur行為;----這個(gè)才是重點(diǎn)
先看看沖突沒(méi)有解決之前的效果;
$("input").focus(function () {
this.value = ""; }).blur(function () {
this.value = "默認(rèn)值"; });$("div").click(function () {
var value = $("input").val();
console.log(value); });
結(jié)果:在input中輸入“aaaa”,然后點(diǎn)擊div,控制臺(tái)輸出的卻是“默認(rèn)值”,與預(yù)想的結(jié)果不符;
解決方法一:在blur的回調(diào)函數(shù)中加一個(gè)定時(shí)器,延遲blur回調(diào)函數(shù)的執(zhí)行時(shí)間,這樣的話(huà)雖然在點(diǎn)擊div的時(shí)候,input的blur行為先被觸發(fā),但是由于加了定時(shí)器延遲,所以得等到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”,然后點(diǎn)擊div,控制臺(tái)輸出的卻是“aaaa”,符合預(yù)想的結(jié)果;
解決方法二:將div的click事件改成mousedown事件,因?yàn)閙ousedown行為是鼠標(biāo)點(diǎn)下去的時(shí)候就被觸發(fā),而click行為是鼠標(biāo)點(diǎn)下去再抬起的時(shí)候才被觸發(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”,然后點(diǎn)擊div,控制臺(tái)輸出的卻是“aaaa”,符合預(yù)想的結(jié)果;
以上所述是小編給大家介紹的jQuery解決input元素的blur事件和其他非表單元素的click事件沖突問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
jQuery實(shí)現(xiàn)頁(yè)面倒計(jì)時(shí)并刷新效果
頁(yè)面倒計(jì)時(shí)小編在很多網(wǎng)站都有這樣的需求,今天小編給大家分享一段jq代碼實(shí)現(xiàn)頁(yè)面倒計(jì)時(shí)并刷新效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),需要的的朋友參考下2017-03-03
jQuery插件FusionCharts實(shí)現(xiàn)的MSBar3D圖效果示例【附demo源碼】
這篇文章主要介紹了jQuery插件FusionCharts實(shí)現(xiàn)的MSBar3D圖效果,結(jié)合完整實(shí)例形式分析了jQuery使用FusionCharts載入xml數(shù)據(jù)繪制MSBar3D圖的相關(guān)操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03
jQuery插件Validate實(shí)現(xiàn)自定義表單驗(yàn)證
這篇文章主要介紹了jQuery插件Validate實(shí)現(xiàn)自定義表單驗(yàn)證,自定義一個(gè)驗(yàn)證方法,感興趣的小伙伴們可以參考一下2016-01-01
jquery 刪除節(jié)點(diǎn) 添加節(jié)點(diǎn) 找兄弟節(jié)點(diǎn)的簡(jiǎn)單實(shí)現(xiàn)
下面小編就為大家?guī)?lái)一篇jquery 刪除節(jié)點(diǎn) 添加節(jié)點(diǎn) 找兄弟節(jié)點(diǎn)的簡(jiǎn)單實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-12-12
jquery 多行滾動(dòng)代碼(附詳細(xì)解釋)
在網(wǎng)上可以隨處找到這段代碼,但是沒(méi)有任何人解釋這段代碼,只要自己研究好久。2010-06-06
jquery+ajax+C#實(shí)現(xiàn)無(wú)刷新操作數(shù)據(jù)庫(kù)數(shù)據(jù)的簡(jiǎn)單實(shí)例
本篇文章主要是對(duì)jquery+ajax+C#實(shí)現(xiàn)無(wú)刷新操作數(shù)據(jù)庫(kù)數(shù)據(jù)的簡(jiǎn)單實(shí)例進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02
jquery中each循環(huán)的簡(jiǎn)單回滾操作
本篇文章主要介紹了jquery中each循環(huán)的簡(jiǎn)單回滾操作的相關(guān)知識(shí),具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-05-05

