1 //返回函數調用者 2 //caller的應用場景 主要用於察看函數自己被哪一個函數調用 3 function fn() { 4 //判斷某函數是否被調用 5 if (fn.caller) { 6 alert(fn.caller.toString()); 7 } else { 8 alert("函數直接執行"); 9 } 10 } 11 function handleCaller() { 12 fn(); 13 } 14 // fn被其餘函數調用 15 handleCaller(); 16 //fn沒有被其它函數調用而是直接執行 17 fn();
1 // 返回正被執行的 Function 對象,也就是所指定的 Function 對象的正文. 2 // callee是arguments 的一個屬性成員,它表示對函數對象自己的引用 3 // arguments.callee.length能夠獲取實參參數 4 5 6 //callee用處1 用來判斷實際參數跟行參是否一致 7 function calleeLengthDemo(arg1, arg2) { 8 // callee表示當前正在執行的函數對象,實際上是函數的一個實例化 9 alert(arguments.callee.toString()); 10 if (arguments.length == arguments.callee.length) { 11 window.alert("驗證形參和實參長度正確!"); 12 return; 13 } else { 14 alert("實參長度:" + arguments.length); 15 alert("形參長度: " + arguments.callee.length); 16 } 17 } 18 //當函數被執行的時候,生成一個實例 19 calleeLengthDemo(1); 20 21 22 //callee用處2 調用自身 - 好比遞歸函數 23 // 優勢:這樣就讓代碼更加簡練。又防止了全局變量的污染 24 //以下是一個遞歸算法 - 計算 1+2+3+4+...+n 25 var fn=(function(n){ 26 if(n>0) return n+arguments.callee(n-1); 27 return 0; 28 })(10); 29 alert('採用callee方式:'+fn); 30 31 32 // 傳統方式的缺點: 33 // 1,破壞了,零重複法則,當一旦函數名稱更改,須要更改多處 34 // 2,fn是一個全局變量,fn內部通常使用局部bianliang,而這裏是一個全局變量,這是一個潛在的全局變量污染 35 var fn=function(n){ 36 if(n>0) return n+fn(n-1); 37 return 0; 38 } 39 alert('採用傳統方式'+fn(10));
1 // 什麼是構造函數 - -專門用於建立對象或者累的函數 -- 由於js中原來沒有對象的概念,經過函數來間接實現面向對象 2 //咱們將建立對象的時候那個函數稱之爲構造函數 3 //咱們能夠經過constructor屬性獲取某個對象的構造函數 4 //constructor 屬性就是用來構造對象實例的函數引用 - 後面的知識點 5 //構造函數 建立的對象 6 function Student(name) { 7 this.name = name; 8 } 9 var zhangsan = new Student('張三'); 10 if (zhangsan.constructor == Student) 11 document.write("zhangsan是根據構造函數Student創造(實例化)出來的"+"<br />"); 12 13 14 //字符串對象 15 var str = new String("Hi"); 16 if (str.constructor == String) 17 document.write("str是根據構造函數String創造(實例化)出來的"); 18 19 // 輸出: 20 // 學生類的構造函數是Student函數 21 // str的構造函數是String
1 // prototype屬性 -- 原型建立對象的底層原理 - 重點 __proto__ 2 //獲取對象的原型。 3 //每個構造函數都有一個prototype屬性,指向另外一個對象。 4 //這個對象的全部屬性和方法,都會被構造函數的實例繼承。 5 //這意味着,咱們能夠把那些不變的屬性和方法,直接定義在prototype對象上。 6 7 // 目前只須要掌握通俗理解方式:對象的建立其實包含兩個部分:構造函數部分,原型部分 8 // 當咱們new一個對象的實例的時候,這個實例可以同時擁有構造函數對象和原型對象的屬性和方法就是經過prototype屬性來實現的 9 // 具體實現方式,下次詳細講解 10 11 12 //古代的男人 13 function Man(name, age) { 14 this.name = name; 15 this.age = age; 16 } 17 18 19 //這裏實際上是兩個對象 Man 和 Man.prototype 20 //這兩個對象經過prototype屬性實現關聯 21 //關聯後的結果,Man對象繼承Man.prototype,從而使得Man擁有Man.prototype的全部屬性和方法 22 23 24 Man.prototype.sex = "純爺們"; 25 //方法:戰鬥 26 Man.prototype.struggle = function () { 27 alert("方天畫戟,赤兔,征戰沙場!!"); 28 } 29 30 //實例化一個男人 31 var 呂布 = new Man("呂布", 20); 32 alert(呂布.sex);//純爺們 33 呂布.struggle();//方天畫戟,赤兔,征戰沙場!! 34 35 36 //古代女人 37 function Woman(name, age) { 38 this.name = name; 39 this.age = age; 40 } 41 Woman.prototype.sex = "小家碧玉"; 42 Woman.prototype.zhibu = function () { 43 alert("織布 歌舞 琴棋書畫"); 44 } 45 var 貂蟬 = new Woman("貂蟬", 16); 46 alert(貂蟬.sex);//小家碧玉 47 貂蟬.zhibu();//d織布 歌舞 琴棋書畫