有過相關經(jīng)驗的朋友都知道,Jscript的效率畢竟有限,在數(shù)組中查找數(shù)據(jù)時如果用常規(guī)的算法來做執(zhí)行起來會很慢。
例如在一個含500個字符串的data數(shù)組里,我們想要找到一個指定的字符(key),返回它的數(shù)組下標,如果用這樣的算法:
CODE: function usual_search(data,key) { var m=data.length for(i=0;i<m;i++) {if(data[i]==key)return i} }
由于需要做多次的比較,運算起來會相當?shù)穆?/p>
本主題要介紹的是一種充分利用Jscript內(nèi)置方法來實現(xiàn)在數(shù)組中查找數(shù)據(jù)的方法,由于借助Jscript內(nèi)置方法,其效率要遠優(yōu)于上述常規(guī)算法。為了(詼諧|唬人)起見,我命其名為“JS暴虐查找法”。
這種查找法對于數(shù)組元素有一個要求:就是數(shù)組元素的內(nèi)容不得包含半角逗號(,)及我們指定的某一個代置符號(例如,在下面的示例中,我們指定代置符號為一個制表符“┢”)。在事先構建、維護數(shù)組時要注意滿足這一要求。
JS暴虐查找法的思路是非常簡單的,原則只有一個,就是要“充分利用Jscript內(nèi)置方法”:
我們首先利用 Array 對象的 toString() 方法產(chǎn)生一個包含數(shù)組元素的字符串,在這個字符串中各數(shù)組元素由半角逗號(,)分隔的,所以我們事先要求數(shù)組元素的內(nèi)容不得包含半角逗號。
隨后利用 String 對象的 replace() 方法將這個字符串中所包含的我們要找的關鍵字符串替換成我們指定的一種特殊符號(代置符號),一般選擇一個不常用的字符來充當代置符號,在下面示例中我使用了一個制表符(┢),只要是能夠確保不會在數(shù)組元素中出現(xiàn)的符號都可以充當代置符號。
接下來就是我們最暴虐的一步了,還是用 replace() 方法,去除半角逗號(,)和代置符號(┢)以外的所有字符。統(tǒng)統(tǒng)去干凈以后這個字符串就變成了一串半角逗號之中包含著一個代置符號(這模樣:,,,,,,,,,,,,,,,,┢,,,,,,,,,)。
最后,用 String 對象的 indexOf() 方法返回代置符號在這個字符串中的位置,而這個位置恰恰也就是在原來數(shù)組中的數(shù)組下標。
Jscript示例程序:
運行代碼框
[Ctrl+A 全部選擇 提示:你可先修改部分代碼,再按運行]
不應該忽略的是:是腳本執(zhí)行非內(nèi)置算法代碼的低效率使得這個JS暴虐查找法有意義。
經(jīng)典論壇討論: http://bbs.blueidea.com/viewthread.php?tid=2455812
出處:藍色理想
責任編輯:moby
◎進入論壇網(wǎng)頁制作、網(wǎng)站綜合版塊參加討論
|