Js 獲取當(dāng)前函數(shù)參數(shù)對象的實(shí)現(xiàn)代碼
有時候在封裝控件的時候在很多 Js 函數(shù)中需要獲取傳入的直接參數(shù)或者對象參數(shù),那么我們就需要每次都去判斷第一個對象,所以為了方便在此封裝一個函數(shù),來獲取當(dāng)前函數(shù)中的參數(shù)值:
/*------------------------------------------ * 清除字符串兩端空格,包含換行符、制表符 *------------------------------------------*/ String.prototype.Trim = function () { return this.replace(/(^[\s\n\t]+|[\s\n\t]+$)/g, ""); } /*---------------------------------------- * 獲取當(dāng)前函數(shù)的參數(shù)對象 *---------------------------------------- * diffCase 是否區(qū)分大小寫,默認(rèn) false *----------------------------------------*/ function GetArgs(diffCase) { //返回參數(shù)對象 var result = new Object(); //獲取調(diào)用函數(shù) var caller = arguments.callee.caller; if (caller == null || caller.arguments.length == 0) return result; //獲取函數(shù)的參數(shù)集合 var matchs = caller.toString().match(/\s*function[\w\s]*\(([\w\s,]*)\)/); if (matchs == null) return result; var argArray = matchs[1].split(","); //獲取參數(shù)對象 var params = caller.arguments[0]; var index = typeof (params) == "object" ? 1 : 0; if (index == 1) { for (var p in params) { for (var i = 0; i < argArray.length; i++) { var arg = argArray[i].Trim(); if (diffCase) { if (arg == p) { result[arg] = params[p]; break; } } else { if (arg.toLocaleLowerCase() == p.toLocaleLowerCase()) { result[arg] = params[p]; break; } } } } } //多個參數(shù)將第一個后面的參數(shù)覆蓋對象傳入的參數(shù) for (var i = index; i < argArray.length && i < caller.arguments.length; i++) result[argArray[i].Trim()] = caller.arguments[i]; return result; }
調(diào)用示例:
//測試函數(shù) function Test(name, age) { //獲取參數(shù)對象 var args = GetArgs(); alert("姓名:" + args.name + ",年齡:" + args.age); } //調(diào)用測試 Test("張三", 25); Test({ name: "李四", age: 30 }); Test({ name: "王五" }, 18);
相關(guān)文章
JavaScript進(jìn)階之前端文件上傳和下載示例詳解
這篇文章主要為大家介紹了JavaScript進(jìn)階之前端文件上傳和下載示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09Bootstrap Tree View簡單而優(yōu)雅的樹結(jié)構(gòu)組件實(shí)例解析
本文通過實(shí)例代碼給大家介紹了Bootstrap Tree View簡單而優(yōu)雅的樹結(jié)構(gòu)組件,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-06-06JavaScript數(shù)據(jù)類型及相互間的轉(zhuǎn)換規(guī)則
這篇文章主要介紹了JavaScript數(shù)據(jù)類型及相互間的轉(zhuǎn)換規(guī)則,文章通過圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09簡單js代碼實(shí)現(xiàn)selece二級聯(lián)動(推薦)
這篇文章主要介紹了簡單js代碼實(shí)現(xiàn)selece二級聯(lián)動的簡單實(shí)例。需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02javascript之DIV拖動類 支持在FF下拖動,調(diào)用簡單
javascript之DIV拖動類 支持在FF下拖動,調(diào)用簡單...2007-08-08