jQuery setTimeout傳遞字符串參數(shù)報錯的解決方法
更新時間:2014年06月09日 17:27:56 作者:
這篇文章主要介紹了jQuery setTimeout傳遞字符串參數(shù)報錯的解決方法,需要的朋友可以參考下
當(dāng)你打算調(diào)用一些jQuery代碼顯示隱藏的一個元素,并調(diào)用setTimeout()在一段延時之后設(shè)置其HTML的內(nèi)容:
整個頁面的代碼是這樣的.
<span style="font-size:18px;"><html>
<head>
<title></title>
</head>
<body>
<a href="#" id='heihei' onclick="showNext('I am veinei ')">show next</a>
<a href="#" id="log" style="display:none" >yes,I am the next </a>
<script type="text/javascript" src="jquery-1.10.2.min.js"></script>
<script type="text/javascript">
function showNext(text){
setTimeout("$('#log').show().text(text)",1000);
}
</script>
</body>
</html>
</span>
.show()確實調(diào)用成功了.但是.text()調(diào)用失敗了.console顯示 text未定義.
對于這個問題,我確實沒有找到更好的答案...我想是不是jQuery對這個傳入setTimeout()函數(shù)的內(nèi)容做了修改導(dǎo)致變量失效.
我緊接著做了下一個實驗.
<span style="font-size:18px;"><html>
<head>
<title></title>
</head>
<body>
<a href="#" id='heihei' onclick="showNext('I am veinei ')">show next</a>
<a href="#" id="log" style="display:none" >yes,I am the next </a>
<script type="text/javascript" src="jquery-1.10.2.min.js"></script>
<script type="text/javascript">
function showNext(text){
setTimeout("alert(text)",1000);
}
</script>
</body>
</html>
</span>
我要看看是不是確實是jQuery出了問題.得到的是同樣的錯誤.
后來找了本書看了看.發(fā)現(xiàn)了問題的所在.
setTimeout() 接受一個字符串參數(shù)時,它執(zhí)行于全局作用域,也就是說,它位于任何函數(shù)之外.最簡單的修復(fù)手段就是使用一個局部函數(shù)(匿名函數(shù))來解決這個問題.
<span style="font-size:18px;"><html>
<head>
<title></title>
</head>
<body>
<a href="#" id='heihei' onclick="showNext('I am veinei ')">show next</a>
<a href="#" id="log" style="display:none" >yes,I am the next </a>
<script type="text/javascript" src="jquery-1.10.2.min.js"></script>
<script type="text/javascript">
function showNext(text){
setTimeout(function(){$('#log').show().text(text);},1000);
}
</script>
</body>
</html>
</span>
成功解決這個問題.
整個頁面的代碼是這樣的.
復(fù)制代碼 代碼如下:
<span style="font-size:18px;"><html>
<head>
<title></title>
</head>
<body>
<a href="#" id='heihei' onclick="showNext('I am veinei ')">show next</a>
<a href="#" id="log" style="display:none" >yes,I am the next </a>
<script type="text/javascript" src="jquery-1.10.2.min.js"></script>
<script type="text/javascript">
function showNext(text){
setTimeout("$('#log').show().text(text)",1000);
}
</script>
</body>
</html>
</span>
.show()確實調(diào)用成功了.但是.text()調(diào)用失敗了.console顯示 text未定義.
對于這個問題,我確實沒有找到更好的答案...我想是不是jQuery對這個傳入setTimeout()函數(shù)的內(nèi)容做了修改導(dǎo)致變量失效.
我緊接著做了下一個實驗.
復(fù)制代碼 代碼如下:
<span style="font-size:18px;"><html>
<head>
<title></title>
</head>
<body>
<a href="#" id='heihei' onclick="showNext('I am veinei ')">show next</a>
<a href="#" id="log" style="display:none" >yes,I am the next </a>
<script type="text/javascript" src="jquery-1.10.2.min.js"></script>
<script type="text/javascript">
function showNext(text){
setTimeout("alert(text)",1000);
}
</script>
</body>
</html>
</span>
我要看看是不是確實是jQuery出了問題.得到的是同樣的錯誤.
后來找了本書看了看.發(fā)現(xiàn)了問題的所在.
setTimeout() 接受一個字符串參數(shù)時,它執(zhí)行于全局作用域,也就是說,它位于任何函數(shù)之外.最簡單的修復(fù)手段就是使用一個局部函數(shù)(匿名函數(shù))來解決這個問題.
復(fù)制代碼 代碼如下:
<span style="font-size:18px;"><html>
<head>
<title></title>
</head>
<body>
<a href="#" id='heihei' onclick="showNext('I am veinei ')">show next</a>
<a href="#" id="log" style="display:none" >yes,I am the next </a>
<script type="text/javascript" src="jquery-1.10.2.min.js"></script>
<script type="text/javascript">
function showNext(text){
setTimeout(function(){$('#log').show().text(text);},1000);
}
</script>
</body>
</html>
</span>
成功解決這個問題.
您可能感興趣的文章:
相關(guān)文章
jquery 將當(dāng)前時間轉(zhuǎn)換成yyyymmdd格式的實現(xiàn)方法
下面小編就為大家?guī)硪黄猨query 將當(dāng)前時間轉(zhuǎn)換成yyyymmdd格式的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考2016-06-06jQuery Validate表單驗證入門學(xué)習(xí)
這篇文章主要介紹了jQuery Validate表單驗證入門知識,該插件捆綁了一套有用的驗證方法,包括 URL 和電子郵件驗證,同時提供了一個用來編寫用戶自定義方法的 API,感興趣的小伙伴們可以參考一下2015-12-12jquery 實現(xiàn)兩Select 標(biāo)簽項互調(diào)示例代碼
這篇文章主要與大家分享了jquery實現(xiàn)兩Select標(biāo)簽項互調(diào)的具體實現(xiàn),比較簡單,比較實用2014-09-09利用JQuery+EasyDrag 實現(xiàn)彈出可拖動的Div,同時向Div傳值,然后返回Div選中的值
JQuery是一個優(yōu)秀的Javascript類庫,使得我們曾經(jīng)對JavaScript的痛恨不再,越來越喜歡上了JavaScript,而且更好的是他的plugin眾多.2009-10-10基于jQuery實現(xiàn)的當(dāng)離開頁面時出現(xiàn)提示的實現(xiàn)代碼
基于jQuery實現(xiàn)的當(dāng)離開頁面時出現(xiàn)提示的實現(xiàn)代碼,需要的朋友可以參考下。2011-06-06jquery.combobox中文api和例子,修復(fù)了上面的小bug
關(guān)于jquery.combobox,這個jquery的插件從官網(wǎng)上直接下載下來使用還有bug,以下是我對其api做的簡單翻譯,而且修復(fù)了上面的bug。2011-03-03jQuery 獲取跨域XML(RSS)數(shù)據(jù)的相關(guān)總結(jié)分析
下面小編就為大家?guī)硪黄猨Query 獲取跨域XML(RSS)數(shù)據(jù)的相關(guān)總結(jié)分析。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05