JavaScript中數(shù)組繼承的簡(jiǎn)單示例
在寫一些庫時(shí)經(jīng)常會(huì)用到樹結(jié)構(gòu)的數(shù)據(jù),而且一些樹形結(jié)構(gòu)的數(shù)據(jù)對(duì)從根到葉的路徑獲取需求非常高。比如一個(gè)站點(diǎn)的整個(gè)路由表就是一棵這樣的樹,它的「路徑」實(shí)際上就是 URL 中的 path 部分。所以我好幾次都用了喪心病狂的數(shù)組繼承去實(shí)現(xiàn),下面給大家分享下。
在 JavaScript 中,數(shù)組也屬于 Object 的一種,它也可以繼承。任何兩個(gè)對(duì)象本身就可以有繼承關(guān)系,數(shù)組也不例外。于是我們讓一個(gè)樹的任何一個(gè)節(jié)點(diǎn)都是數(shù)組,它只維護(hù)自己下標(biāo)最大的那個(gè)元素的值。其它元素的值通過原型繼承從祖先節(jié)點(diǎn)繼承而來。這樣我們就可以像操作一般數(shù)組一樣在葉節(jié)點(diǎn)上訪問從根節(jié)點(diǎn)過來的路徑了。下面是一個(gè)簡(jiǎn)易實(shí)現(xiàn):
運(yùn)行
<script> // 定義節(jié)點(diǎn)類 var TNode = function(value) { this.push(value); }; TNode.prototype = []; TNode.prototype.constructor = TNode; TNode.prototype.createChild = function(value) { var node = Object.create(this); TNode.call(node, value); return node; }; // 使用節(jié)點(diǎn)造出一棵簡(jiǎn)單的樹 var root = new TNode('root'); var a = root.createChild('a'); var b = a.createChild('b'); // 將葉節(jié)點(diǎn)視為數(shù)組,直接得到路徑 document.write(b.join('/')); <!-- root/a/b </script>
這個(gè)用法算是比較黑的魔法,如果不懂原型繼承的原理可能很難看懂。所以如果只是作為一個(gè)庫的實(shí)現(xiàn)也許可以這么寫(我已經(jīng)用過好多次了,事實(shí)證明并沒有坑),但直接在業(yè)務(wù)代碼中如果這么用就可能被吐槽到死。雖然這個(gè)用法并沒有違背 JavaScript 這種語言的核心思想。
這個(gè)用法的一個(gè)特點(diǎn)就是祖先節(jié)點(diǎn)的值更新時(shí)會(huì)自動(dòng)同步到所有子節(jié)點(diǎn)上。雖然原型鏈訪問也存在性能開銷,但比起在代碼層自己去遍歷樹已經(jīng)是快得不能再多了。當(dāng)然如果沒有這樣的需求,只是想實(shí)現(xiàn)一棵簡(jiǎn)簡(jiǎn)單單的數(shù)還是使用傳統(tǒng)方式比較好。畢竟這太依賴語言了,以后如果要遷移到別的編程語言可能會(huì)比較困難。
相關(guān)文章
javascript中的對(duì)象和數(shù)組的應(yīng)用技巧
javascript中的對(duì)象和數(shù)組的應(yīng)用技巧...2007-01-01javascript處理a標(biāo)簽超鏈接默認(rèn)事件的方法
這篇文章主要介紹了javascript處理a標(biāo)簽超鏈接默認(rèn)事件的方法,涉及event.preventDefault()方法阻止默認(rèn)事件的使用技巧,需要的朋友可以參考下2015-06-06深入理解Javascript中的自執(zhí)行匿名函數(shù)
下面小編就為大家?guī)硪黄钊肜斫釰avascript中的自執(zhí)行匿名函數(shù)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06JavaScript中關(guān)于indexOf的使用方法與問題小結(jié)
indexOf方法的作用是:根據(jù)給定參數(shù)x返回目標(biāo)字符串(可以看成字符的數(shù)組)或數(shù)組中與x相等的項(xiàng)的索引。2010-08-08js 實(shí)現(xiàn)復(fù)制到粘貼板的功能代碼
主要是用到了 window.clipboardData.setData("Text",copyText);2010-05-05