国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

JavaScript中數(shù)組繼承的簡單示例

2024-05-06 16:23:59
字體:
來源:轉載
供稿:網(wǎng)友

這篇文章主要介紹了JavaScript中數(shù)組繼承的簡單示例,數(shù)組繼承是JavaScript入門學習中的基礎知識,需要的朋友可以參考下

在寫一些庫時經(jīng)常會用到樹結構的數(shù)據(jù),而且一些樹形結構的數(shù)據(jù)對從根到葉的路徑獲取需求非常高。比如一個站點的整個路由表就是一棵這樣的樹,它的「路徑」實際上就是 URL 中的 path 部分。所以我好幾次都用了喪心病狂的數(shù)組繼承去實現(xiàn),下面給大家分享下。

在 JavaScript 中,數(shù)組也屬于 Object 的一種,它也可以繼承。任何兩個對象本身就可以有繼承關系,數(shù)組也不例外。于是我們讓一個樹的任何一個節(jié)點都是數(shù)組,它只維護自己下標最大的那個元素的值。其它元素的值通過原型繼承從祖先節(jié)點繼承而來。這樣我們就可以像操作一般數(shù)組一樣在葉節(jié)點上訪問從根節(jié)點過來的路徑了。下面是一個簡易實現(xiàn):

運行

 

 
  1. <script> 
  2. // 定義節(jié)點類 
  3. var TNode = function(value) { 
  4. this.push(value); 
  5. }; 
  6. TNode.prototype = []; 
  7. TNode.prototype.constructor = TNode; 
  8. TNode.prototype.createChild = function(value) { 
  9. var node = Object.create(this); 
  10. TNode.call(node, value); 
  11. return node; 
  12. }; 
  13.  
  14. // 使用節(jié)點造出一棵簡單的樹 
  15. var root = new TNode('root'); 
  16. var a = root.createChild('a'); 
  17. var b = a.createChild('b'); 
  18.  
  19. // 將葉節(jié)點視為數(shù)組,直接得到路徑 
  20. document.write(b.join('/')); <!-- root/a/b 
  21. </script> 

這個用法算是比較黑的魔法,如果不懂原型繼承的原理可能很難看懂。所以如果只是作為一個庫的實現(xiàn)也許可以這么寫(我已經(jīng)用過好多次了,事實證明并沒有坑),但直接在業(yè)務代碼中如果這么用就可能被吐槽到死。雖然這個用法并沒有違背 JavaScript 這種語言的核心思想。

這個用法的一個特點就是祖先節(jié)點的值更新時會自動同步到所有子節(jié)點上。雖然原型鏈訪問也存在性能開銷,但比起在代碼層自己去遍歷樹已經(jīng)是快得不能再多了。當然如果沒有這樣的需求,只是想實現(xiàn)一棵簡簡單單的數(shù)還是使用傳統(tǒng)方式比較好。畢竟這太依賴語言了,以后如果要遷移到別的編程語言可能會比較困難。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 恭城| 盐池县| 江城| 沅陵县| 伊春市| 新建县| 襄城县| 定结县| 闻喜县| 渝北区| 陆河县| 敖汉旗| 张掖市| 丰都县| 保定市| 宜阳县| 秀山| 枣庄市| 蓬安县| 天水市| 武平县| 冷水江市| 宁陕县| 轮台县| 肃南| 成都市| 虎林市| 南投市| 九龙坡区| 澳门| 渝中区| 盖州市| 红河县| 连云港市| 辽宁省| 姜堰市| 林西县| 泸定县| 利川市| 太谷县| 韶关市|