Js 獲取當前函數(shù)參數(shù)對象的實現(xiàn)代碼
更新時間:2016年06月20日 16:50:57 投稿:mdxy-dxy
這篇文章主要介紹了Js 獲取當前函數(shù)參數(shù)對象的實現(xiàn)代碼,需要的朋友可以參考下
有時候在封裝控件的時候在很多 Js 函數(shù)中需要獲取傳入的直接參數(shù)或者對象參數(shù),那么我們就需要每次都去判斷第一個對象,所以為了方便在此封裝一個函數(shù),來獲取當前函數(shù)中的參數(shù)值:
/*------------------------------------------
* 清除字符串兩端空格,包含換行符、制表符
*------------------------------------------*/
String.prototype.Trim = function () { return this.replace(/(^[\s\n\t]+|[\s\n\t]+$)/g, ""); }
/*----------------------------------------
* 獲取當前函數(shù)的參數(shù)對象
*----------------------------------------
* diffCase 是否區(qū)分大小寫,默認 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中String.prototype用法實例
這篇文章主要介紹了JavaScript中String.prototype用法,實例分析了prototype的功能及使用技巧,需要的朋友可以參考下2015-05-05
knockoutjs模板實現(xiàn)樹形結(jié)構(gòu)列表
這篇文章主要介紹了knockoutjs模板實現(xiàn)樹形結(jié)構(gòu)列表的實現(xiàn)代碼,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2017-07-07
js之如何刪除多層數(shù)組嵌套的最后一層中的部分數(shù)據(jù)
這篇文章主要介紹了js之如何刪除多層數(shù)組嵌套的最后一層中的部分數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
詳解template標簽用法(含vue中的用法總結(jié))
這篇文章主要介紹了template標簽用法(含vue中的用法總結(jié)),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-01-01

