function Foo() { getName = function () { console.log(1)}; //會修改全局的下的getName return this;// 構造函數的返回值值得注意,若是是引用類型,則獲得引用數據,null除外 } Foo.getName = function () { console.log(2);}; Foo.prototype.getName = function () { console.log(3)}; var getName = function () { console.log(4)}; function getName() {console.log(5)} //請寫出如下輸出結果: Foo.getName();//2 getName(); // 4 Foo().getName(); // 1 getName();// 1 new Foo.getName(); // 2 這裏是new了一個Foo.getName函數,並無先執行Foo.getName()在去執行new操做 new Foo().getName(); // 3 (new Foo()).getName() 此時的getName是找到Foo構造函數的原型對象上的getName屬性 new new Foo().getName(); // 3 new ((new Foo()).getName)(); /*******************升級版********************/ // function Foo() { // this.getName = function() { // console.log(3); // return { // getName: getName//這個就是第六問中涉及的構造函數的返回值問題 // } // };//這個就是第六問中涉及到的, JS 構造函數公有方法和原型鏈方法的優先級 // getName = function() { // console.log(1); // }; // return this // } // Foo.getName = function() { // console.log(2); // }; // Foo.prototype.getName = function() { // console.log(6); // }; // var getName = function() { // console.log(4); // }; // function getName() { // console.log(5); // } //答案: // Foo.getName(); //2 // getName(); //4 // console.log(Foo()) // Foo().getName(); //1 // getName(); //1 // new Foo.getName(); //2 // new Foo().getName(); //3 // //多了一問 // new Foo().getName().getName(); //3 1 // new new Foo().getName(); //3