javascript獲取函數(shù)名稱、函數(shù)參數(shù)、對(duì)象屬性名稱的代碼實(shí)例
一、獲取函數(shù)名稱的3種實(shí)現(xiàn)方法
實(shí)例1:
在js權(quán)威指南中看到的一個(gè)方法:
Function.prototype.getName = function(){
return this.name || this.toString().match(/function\s*([^(]*)\(/)[1]
}
實(shí)例2:
如果當(dāng)前函數(shù)是有名函數(shù),則返回其名字,如果是匿名函數(shù)則返回被賦值的函數(shù)變量名,如果是閉包中匿名函數(shù)則返回“anonymous”。
var getFnName = function(callee){
var _callee = callee.toString().replace(/[\s\?]*/g,""),
comb = _callee.length >= 50 ? 50 :_callee.length;
_callee = _callee.substring(0,comb);
var name = _callee.match(/^function([^\(]+?)\(/);
if(name && name[1]){
return name[1];
}
var caller = callee.caller,
_caller = caller.toString().replace(/[\s\?]*/g,"");
var last = _caller.indexOf(_callee),
str = _caller.substring(last-30,last);
name = str.match(/var([^\=]+?)\=/);
if(name && name[1]){
return name[1];
}
return "anonymous"
};
使用:在要調(diào)查的函數(shù)內(nèi)部執(zhí)行此函數(shù),傳入一個(gè)參數(shù),為arguments.callee。
function ee(){
//+++++++++++++++++++++++++++++++++
var fnname =getFnName(arguments.callee)
//+++++++++++++++++++++++++++++++++
alert(fnname)
};
ee();
實(shí)例3:
function getFuncName(_callee)
{
var _text = _callee.toString();
var _scriptArr = document.scripts;
for (var i=0; i<_scriptArr.length; i++)
{
var _start = _scriptArr[i].text.indexOf(_text);
if (_start != -1)
{
if (/^function\s*\(.*\).*\r\n/.test(_text))
{
var _tempArr = _scriptArr[i].text.substr(0, _start).split('\r\n');
return _tempArr[_tempArr.length - 1].replace(/(var)|(\s*)/g, '').replace(/=/g, '');
}
else
return _text.match(/^function\s*([^\(]+).*\r\n/)[1];
}
}
}
function a()
{
return getFuncName(arguments.callee);
}
var b = function()
{
return getFuncName(arguments.callee);
}
window.alert(a());
window.alert(b());
以上的方法還有一個(gè)情況沒法解決,希望有辦法的能給出指點(diǎn)。
var x =
{
run : function()
{
return getFuncName(arguments.callee);
}
}
window.alert(x.run());
這個(gè)情況下無法得到函數(shù)的名稱;
二、js獲取函數(shù)的所有參數(shù)和遍歷某個(gè)對(duì)象所有的屬性名稱和值的方法
1.獲取所有參數(shù)
function test(){
for(var i=0;i<arguments.length;i++)
document.write(arguments[i]);
}
2.遍歷某個(gè)對(duì)象所有的屬性名稱和值的方法
<script language="javascript">
var obj = new Object();
obj.myname = "我是對(duì)象";
obj.pro2 = "23";
obj.pro3 = "abcdeg"; php程序員站
for (items in obj){
document.write("屬性:"+items+"的值是 ("+ obj[items] +")");
document.write("<br>");
}
</script>
相關(guān)文章
javascript中FOREACH數(shù)組方法使用示例
本文給大家介紹的是Array.prototype.forEach()的使用方法示例,希望對(duì)大家學(xué)習(xí)javascript能夠有所幫助。2016-03-03Javascript基礎(chǔ)教程之while語(yǔ)句
這篇文章主要介紹了Javascript基礎(chǔ)教程之while語(yǔ)句的相關(guān)資料,需要的朋友可以參考下2015-01-01表單元素的submit()方法和onsubmit事件應(yīng)用概述
表單元素?fù)碛衧ubmit方法,同時(shí)也具有onsubmit事件句柄,用于監(jiān)聽表單提交。可以使用elemForm.submit();方法觸發(fā)表單提交,感興趣的朋友可以了解下,或許對(duì)你有所幫助2013-02-02javascript?DOM?querySelectorAll()?使用方法
querySelectorAll()?方法返回文檔中匹配指定?CSS?選擇器的所有元素,返回?NodeList?對(duì)象,一般用來獲取指定id火class下的所有節(jié)點(diǎn)2023-06-06詳解js運(yùn)算符單豎杠“|”與“||”的用法和作用介紹
在js開發(fā)應(yīng)用中我們通常會(huì)碰到“|”與“||”了,那么在運(yùn)算中“|”與“||”是什么意思呢?本篇文章主要介紹了詳解js運(yùn)算符單豎杠“|”與“||”的用法,有需要的可以了解一下。2016-11-11淺析document.ready和window.onload的區(qū)別講解
這篇文章主要介紹了document.ready和window.onload的區(qū)別,有需要的朋友可以參考一下2013-12-12