欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用apply讓javascript函數(shù)僅執(zhí)行一次的代碼

 更新時間:2010年06月27日 02:38:47   作者:  
有時候我們只想要讓某些腳步函數(shù)執(zhí)行一次就算完成任務(wù)了。如何實現(xiàn)這種功能呢?簡單模仿下面這段就可以輕松搞定了
復(fù)制代碼 代碼如下:

var obj = new Object();
obj.triggerOnce = function(fn) { //控制讓函數(shù)只觸發(fā)一次
return function() {
try {
fn.apply(this, arguments);
}
catch (e) {
var txt = "There was an error on this page.\n\n";
txt += "Error message: " + e.message + "\n\n";
txt += "Error name: " + e.name + "\n\n";
//alert(txt);//正式平臺上可能需要注釋掉該行
}
finally {
fn = null;
}
}
}

調(diào)用形式:
復(fù)制代碼 代碼如下:

function showMsg(arg){
alert(arg);
}
var fn=obj.triggerOnce(showMsg);
fn(1);//只執(zhí)行一次
fn(2);//沒有調(diào)用fn

最后,關(guān)于javascript的apply方法,您可以簡單參考這篇舊文。
【外一篇】用javascript取得querystring的值
在常見的網(wǎng)站中,經(jīng)常碰到有“XXXX.aspx?username=jeffwong&address=北京” 這種形式的url,通過asp.net的Request對象獲取鍵值輕而易舉,通過js也不是很難,用下面的函數(shù)就可以搞定了:
代碼
復(fù)制代碼 代碼如下:

var urlStrs = location.search; //QueryString
var Request = {};
Request.Count = 0;
Request.Add = function(name, value) {
if (Request.hasOwnProperty(name) == false) {
Request.Count++; //如果不存在,計數(shù)添加1
}
Request[name] = value;
return true;
}
Request.QueryString = function(name) {//取對應(yīng)的鍵值
var key = name.toString().toLocaleLowerCase(); //不區(qū)分大小寫
var result = null;
try {
// if (Request.hasOwnProperty(key)) {
result = Request[key];
// }
}
catch (e) {
//alert(e.message);
}
return result;
}
Request.Init = function(urlQueryString) {
if (urlQueryString.indexOf("?") != -1) {
var url = urlQueryString.substr(1)
var strArr = url.split("&");
for (var i = 0; i < strArr.length; i++) {
var strChildArr = strArr[i].split("=");
var name = String(strChildArr[0]).toLowerCase();
var value = unescape(strChildArr[1]); //unescape解碼
this.Add(name, value); //添加
}
}
}

測試函數(shù)如下:
代碼
復(fù)制代碼 代碼如下:

//測試函數(shù)
function test() {
Request.Init(urlStrs); //初始化request
alert(Request.Count);
var name = "username";
var value = Request.QueryString(name);
alert(Request[name]);
alert(Request.QueryString(name));
name = "address"
alert(Request[name]);
alert(Request.QueryString(name));
name = "age";
alert(Request[name]);
alert(Request.QueryString(name));
}

需要說明的是,url里的參數(shù)通常都會有編碼,本文采用的是比較常用的unescape進行解碼,實際上,關(guān)于url參數(shù)編碼,通常有escape,encodeURIComponent和encodeURI這三種編碼函數(shù),escape是window對象的內(nèi)置函數(shù),而另外兩種則是javascript內(nèi)置函數(shù),它們解碼的函數(shù)也是一一對應(yīng)的關(guān)系(您可以參考這一篇),各自對應(yīng)的反轉(zhuǎn)函數(shù)分別是unescape,decodeURIComponent和decodeURI。
作者:Jeff Wong

相關(guān)文章

  • JS實現(xiàn)代碼雨特效

    JS實現(xiàn)代碼雨特效

    這篇文章主要為大家詳細介紹了JS實現(xiàn)代碼雨特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • javascript 使用 NodeList需要注意的問題

    javascript 使用 NodeList需要注意的問題

    理解NodeList及其近親NamedNodeMap和HTMLCollection,是從整體上透徹理解DOM的關(guān)鍵所在,這三個集合都是“動態(tài)的”,換句話說,每當文檔結(jié)構(gòu)發(fā)生變化時,他們都會得到更新。
    2013-03-03
  • 原生js實現(xiàn)購物車

    原生js實現(xiàn)購物車

    這篇文章主要為大家詳細介紹了原生js實現(xiàn)購物車,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • 詳解JavaScript中分解數(shù)字的三種方法

    詳解JavaScript中分解數(shù)字的三種方法

    這篇文章主要介紹了在JavaScript中分解數(shù)字的三種方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • 基于JavaScript實現(xiàn)鼠標箭頭移動圖片跟著移動

    基于JavaScript實現(xiàn)鼠標箭頭移動圖片跟著移動

    這篇文章主要介紹了基于JavaScript實現(xiàn)鼠標箭頭移動圖片跟著移動的核心代碼,代碼比較簡單易懂,需要的朋友可以參考下
    2016-08-08
  • 前端如何監(jiān)聽手機鍵盤是否彈起示例詳解

    前端如何監(jiān)聽手機鍵盤是否彈起示例詳解

    實際應(yīng)用中我們會遇到監(jiān)聽按鍵輸入和鼠標點擊事件,這篇文章主要介紹了前端如何監(jiān)聽手機鍵盤是否彈起的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-02-02
  • js利用遞歸與promise 按順序請求數(shù)據(jù)的方法

    js利用遞歸與promise 按順序請求數(shù)據(jù)的方法

    這篇文章主要介紹了js利用遞歸與promise 按順序請求數(shù)據(jù),需要的朋友可以參考下
    2019-08-08
  • JS組件Bootstrap實現(xiàn)下拉菜單效果代碼

    JS組件Bootstrap實現(xiàn)下拉菜單效果代碼

    這篇文章主要為大家詳細介紹了JS組件Bootstrap實現(xiàn)下拉菜單效果代碼,感興趣的小伙伴們可以參考一下
    2016-04-04
  • javascript實現(xiàn)當前頁導(dǎo)航激活的方法

    javascript實現(xiàn)當前頁導(dǎo)航激活的方法

    這篇文章主要介紹了javascript實現(xiàn)當前頁導(dǎo)航激活的方法,涉及javascript操作css的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-02-02
  • 原生js實現(xiàn)下拉框選擇組件

    原生js實現(xiàn)下拉框選擇組件

    這篇文章主要為大家詳細介紹了原生js實現(xiàn)下拉框選擇組件的開發(fā),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01

最新評論