javascript 易錯知識點實例小結
本文實例總結了javascript 易錯知識點。分享給大家供大家參考,具體如下:
為什么 typeof null === 'object'
原理是這樣的,不同的對象在底層都表示為二進制,在JavaScript中二進制前三位都為0的話會被判斷為 object 類型, null 的二進制表示是全0,自然前三位也是0,所以執(zhí)行 typeof 時會返回“ object ”。
對象屬性的存在性
如 myObject.a 的屬性訪問返回值可能是 undefined ,但是這個值有可能是屬性中存儲的 undefined ,也可能是因為屬性不存在所以返回 undefined 。那么如何區(qū)分這兩種情況呢?
var myObject = {
a:2
};
// 方案一
("a" in myObject); // true
("b" in myObject); // false
// 方案二
myObject.hasOwnProperty( "a" ); // true
myObject.hasOwnProperty( "b" ); // false
// 方案三
Object.prototype.hasOwnProperty.call(myObject, 'b')
對象繼承的三種方法
參考如下代碼:
function Foo(name) {
this.name = name;
}
Foo.prototype.myName = function() {
console.log(this.name)
}
function Bar(name, label) {
Foo.call(this, name);
this.label = label;
}
// 方法1
Bar.prototype = Object.create(Foo.prototype)
// 方法2
Bar.prototype = Foo.prototype;
// 方法3
Bar.prototype = new Foo();
//Bar.prototype.constructor = Bar;
Bar.prototype.sayName = function() {
console.log(this.name)
}
var b = new Foo('fayin')
b.sayName()
上例中,三種方法都可以使 Bar 繼承 Foo.prototype 上的方法,但它們之間又有微妙的差別:
Object.create(..) 會憑空創(chuàng)建一個“新”對象并把新對象內部的 [[Prototype]] 關聯(lián)到你指定的對象(本例中是 Foo.prototype )。
Bar.prototype = Foo.prototype 并不會創(chuàng)建一個關聯(lián)到 Bar.prototype 的新對象,它只是讓 Bar.prototype 直接引用 Foo.prototype 對象。因此當你執(zhí)行類似 Bar.prototype.myLabel = ... 的賦值語句時會直接修改 Foo.prototype 對象本身。
Bar.prototype = new Foo() 的確會創(chuàng)建一個關聯(lián)到 Bar.prototype 的新對象。但是它使用了 Foo(..)的“構造函數調用”,如果函數 Foo 有一些副作用(比如寫日志、修改狀態(tài)、注冊到其他對象、給 this 添加數據屬性,等等)的話,就會影響到 Bar() 的“后代”,后果不堪設想。
結論
因此,要創(chuàng)建一個合適的關聯(lián)對象,我們必須使用 Object.create(..) 而不是使用具有副作用的 Foo(..) 。這樣做唯一的缺點就是需要創(chuàng)建一個新對象然后把舊對象拋棄掉,不能直接修改已有的默認對象。
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。
更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript錯誤與調試技巧總結》、《JavaScript傳值操作技巧總結》、《javascript編碼操作技巧總結》、《JavaScript中json操作技巧總結》、《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
相關文章
發(fā)布一個基于javascript的動畫類 Fx.js
支持大部分CSS3屬性的動畫(可能要指定詳細的屬性值)。2010-11-11
Javascript 詳解封裝from表單數據為json串進行ajax提交
這篇文章主要介紹了Javascript 詳解封裝from表單數據為json串進行ajax提交的相關資料,需要的朋友可以參考下2017-03-03

