亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

javascript 易錯知識點實例小結

瀏覽:6日期:2023-11-01 18:31:52

本文實例總結了javascript 易錯知識點。分享給大家供大家參考,具體如下:

為什么 typeof null === ’object’

原理是這樣的,不同的對象在底層都表示為二進制,在JavaScript中二進制前三位都為0的話會被判斷為 object 類型, null 的二進制表示是全0,自然前三位也是0,所以執行 typeof 時會返回“ object ”。

對象屬性的存在性

如 myObject.a 的屬性訪問返回值可能是 undefined ,但是這個值有可能是屬性中存儲的 undefined ,也可能是因為屬性不存在所以返回 undefined 。那么如何區分這兩種情況呢?

var myObject = { a:2};// 方案一('a' in myObject); // true('b' in myObject); // false// 方案二myObject.hasOwnProperty( 'a' ); // truemyObject.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;}// 方法1Bar.prototype = Object.create(Foo.prototype)// 方法2Bar.prototype = Foo.prototype;// 方法3Bar.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(..) 會憑空創建一個“新”對象并把新對象內部的 [[Prototype]] 關聯到你指定的對象(本例中是 Foo.prototype )。

Bar.prototype = Foo.prototype 并不會創建一個關聯到 Bar.prototype 的新對象,它只是讓 Bar.prototype 直接引用 Foo.prototype 對象。因此當你執行類似 Bar.prototype.myLabel = ... 的賦值語句時會直接修改 Foo.prototype 對象本身。

Bar.prototype = new Foo() 的確會創建一個關聯到 Bar.prototype 的新對象。但是它使用了 Foo(..)的“構造函數調用”,如果函數 Foo 有一些副作用(比如寫日志、修改狀態、注冊到其他對象、給 this 添加數據屬性,等等)的話,就會影響到 Bar() 的“后代”,后果不堪設想。

結論

因此,要創建一個合適的關聯對象,我們必須使用 Object.create(..) 而不是使用具有副作用的 Foo(..) 。這樣做唯一的缺點就是需要創建一個新對象然后把舊對象拋棄掉,不能直接修改已有的默認對象。

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript錯誤與調試技巧總結》、《JavaScript傳值操作技巧總結》、《javascript編碼操作技巧總結》、《JavaScript中json操作技巧總結》、《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 亚洲精品国产成人7777 | 亚洲欧美一区在线 | 国产亚洲精品hd网站 | 永久黄网站色视频免费网站 | 222aaa免费国产在线观看 | 欧美自拍视频在线 | 欧美成人四级hd版 | 欧美日韩另类综合 | 亚洲在线精品 | 亚洲国产成人最新精品资源 | 中文字幕视频在线观看 | 国产伦精品一区二区三区无广告 | 日本韩国一级片 | 美女一级毛片毛片在线播放 | 亚洲男人的天堂久久香蕉 | 日韩欧美一级毛片精品6 | 精品午夜国产在线观看不卡 | 欧美jizzhd精品欧美高清 | 精品国产精品a | 日韩视频久久 | 91精品国产免费网站 | 欧美成人午夜免费完成 | 在线播放高清国语自产拍免费 | 欧美高清日本三级人妇 | 精品欧美一区二区精品久久 | 日本韩国三级在线观看 | 97久久精品午夜一区二区 | 久久精品午夜视频 | 国产三级精品播放 | 免费看真人a一级毛片 | 国产农村一二三区 | 国内精品久久久久久久久蜜桃 | 亚洲精品一区二区三区国产 | 亚洲精品国产啊女成拍色拍 | 国产美女午夜精品福利视频 | 亚洲精品久久精品h成人 | 欧美xxxx性xxxxx高清视频 | 亚洲香蕉久久一区二区三区四区 | 99精品网站 | 免费老外的毛片清高 | 亚洲美女免费视频 |