日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

冷門Javascript API——element.insertAdjacent

系統 4318 0

John Resig(jQuery的作者)在2008年的時候曾經嘗試將elment.insertAdjacentHTML引入jQuery,不過他最終放棄了。主要原因在于:

  • 其在IE6中不支持向table,tbody,thead或者tr插入html,否則會拋出錯誤。
  • 不支持XML文檔。

不過當時,這一由IE4.0開始出現的接口已經進入了HTML5的接口名單,將會有更多瀏覽器實現該接口,下面便是目前桌面瀏覽器的支持情況:

?

Feature Chrome Firefox (Gecko) Internet Explorer Opera Safari (WebKit)
Basic support 1.0 8.0 (8.0) 4.0 7.0 4.0 (527)

?

但是,我們為什么會關注這一接口呢?

?

比element.innerHTML更好的性能

測試結果表明,element.insertAdjacentHTML在大部分情況下有比element.innerHTML更好的性能:

http://jsperf.com/insertadjacenthtml-perf/4

這可能是比Document Fragments更好的HTML文檔插入方案,因為我們知道Document Fragments在某些IE版本中的表現比較糟糕(看來IE的實現方式和別的都不太一樣啊……)。

這給我們得模板優化提供了可行而簡易的方案。

好吧,那element.insertAdjacentHTML這接口怎么用呢?

?

在指定位置插入HTML

element.insertAdjancentHTML(position, html)

需要傳入字符串參數position,以及字符串參數html代碼。我們可以對照jQuery的HTML插入方法,得到這一position的對照關系:

.insertAdjacentHTML("beforeBegin", ...) ?—— ?before

.insertAdjacentHTML("afterBegin", ...) ?—— ?prepend

.insertAdjacentHTML("beforeEnd", ...) ?—— ?append

.insertAdjacentHTML("afterEnd", ...) ?—— ?after

即:

beforeBegin:在該元素前插入

afterBegin:在該元素第一個子元素前插入

beforeEnd:在該元素最后一個子元素后面插入

afterEnd:在該元素后插入

?不過,當元素是空的時候,其和innerHTML就可以很相像了,比如:

      
        var
      
       menu = document.createElment("div"
      
        );
menu.insertAdjacentHTML(
      
      "afterEnd"
      
        ,
    
      
      "<p>Hello world!</p>");
    

這里就和menu.innerHTML('<p>Hello world!</p>')是一樣的。

?

總結?

主要還是看需求。由于我們的項目可以不考慮IE6,所以IE6的問題就不是問題了。而且模板引擎不會插入XML Document,所以第二個問題也不是問題了。

?

參考資料

DOM insertAdjacentHTML ?.?John Resig

element.insertAdjacentHTML ?. MDN

?

冷門Javascript API——element.insertAdjacentHTML


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 金山区| 天峨县| 灌阳县| 嵊泗县| 手机| 贵阳市| 方山县| 永嘉县| 扎囊县| 莲花县| 东阳市| 顺平县| 新田县| 宜宾县| 横峰县| 特克斯县| 秦皇岛市| 东宁县| 当阳市| 石柱| 延边| 大庆市| 贵港市| 上林县| 宜宾市| 临泉县| 江城| 安徽省| 克什克腾旗| 新干县| 鄱阳县| 安西县| 东兰县| 介休市| 静安区| 苏州市| 雷波县| 时尚| 柏乡县| 丘北县| 密山市|