1. 程式人生 > >javascript如何獲取函式名稱和引數方法例項詳解

javascript如何獲取函式名稱和引數方法例項詳解

一、獲取函式名稱的3種實現方法

 

例項1:

在js權威指南中看到的一個方法:

1

2

3

Function.prototype.getName = function(){

    return this.name || this.toString().match(/function\s*([^(]*)\(/)[1]

}

例項2:

如果當前函式是有名函式,則返回其名字,如果是匿名函式則返回被賦值的函式變數名,如果是閉包中匿名函式則返回“anonymous”。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

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"

};

使用:在要調查的函式內部執行此函式,傳入一個引數,為arguments.callee。

1

2

3

4

5

6

7

function  ee(){

      //+++++++++++++++++++++++++++++++++

      var fnname =getFnName(arguments.callee)

      //+++++++++++++++++++++++++++++++++

      alert(fnname)

    };

ee();

例項3:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

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());

二、js獲取函式的所有引數和遍歷某個物件所有的屬性名稱和值的方法

1.獲取所有引數

1

2

3

function test(){

for(var i=0;i<arguments.length;i++) document.write(arguments[i]);

}

2.遍歷某個物件所有的屬性名稱和值的方法

1

2

3

4

5

6

7

8

9

10

<script language="javascript">

var obj = new Object();

obj.myname = "我是物件";

obj.pro2 = "23";

obj.pro3 = "abcdeg"; php程式設計師站

for (items in obj){

 document.write("屬性:"+items+"的值是 ("+ obj[items] +")");

 document.write("<br>");

}

</script>

以上就是javascript如何獲取函式名稱和引數方法例項詳解的詳細內容,更多請關注php中文網其它相關文章!

轉載於:http://www.php.cn/js-tutorial-375024.html