巧用apply讓javascript函數僅執行一次

來源:互聯網
上載者:User

RT,有時候我們只想要讓某些腳步函數執行一次就算完成任務了。如何?這種功能呢?簡單模仿下面這段就可以輕鬆搞定了:

代碼

var obj = new Object();

obj.triggerOnce = function(fn) { //控制讓函數只觸發一次
    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;
        }
    }
}

調用形式:


function showMsg(arg){
   alert(arg);
}

var fn=obj.triggerOnce(showMsg);
fn(1);//只執行一次
fn(2);//沒有調用fn

 最後,關於javascript的apply方法,您可以簡單參考這篇舊文。

 
外一篇】用javascript取得querystring的值
在常見的網站中,經常碰到有“XXXX.aspx?username=jeffwong&address=北京” 這種形式的url,通過asp.net的Request對象擷取索引值輕而易舉,通過js也不是很難,用下面的函數就可以搞定了:

代碼

var urlStrs = location.search; //QueryString
var Request = {};
Request.Count = 0;

Request.Add = function(name, value) {
    if (Request.hasOwnProperty(name) == false) {
        Request.Count++; //如果不存在,計數添加1
    }
    Request[name] = value;
    return true;
}

Request.QueryString = function(name) {//取對應的索引值
    var key = name.toString().toLocaleLowerCase(); //不區分大小寫
    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); //添加
        }
    }
}

測試函數如下:代碼

//測試函數
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裡的參數通常都會有編碼,本文採用的是比較常用的unescape進行解碼,實際上,關於url參數編碼,通常有escape,encodeURIComponent和encodeURI這三種編碼函數,escape是window對象的內建函數,而另外兩種則是javascript內建函數,它們解碼的函數也是一一對應的關係(您可以參考這一篇),各自對應的反轉函數分別是unescape,decodeURIComponent和decodeURI。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.