DOM常用外部插入方法與區別

小周sri的碼農發表於2017-09-08

1.DOM外部插入after()與before()

節點與節點之前有各種關係,除了父子,祖輩關係,還可以是兄弟關係。之前我們在處理節點插入的時候,接觸到了內部插入的幾個方法,這節我們開始講外部插入的處理,也就是兄弟之間的關係處理,這裡jQuery引入了2個方法,可以用來在匹配I的元素前後插入內容。

選擇器 描述
.after(content)

在匹配選擇器的每個元素之後插入內容(作為兄弟節點)

.before(content)

方法在匹配選擇器的元素之前插入內容(作為兄弟節點)

 

before與after都是用來對相對選中元素外部增加相鄰的兄弟節點

2個方法都是都可以接收HTML字串,DOM 元素,元素陣列,或者jQuery物件,用來插入到集合中每個匹配元素的前面或者後面

2個方法都支援多個引數傳遞after(div1,div2,....) 
<!DOCTYPE html>
<html>

<head>
    <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
    <title></title>
    <script src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script>
    <style>
    .aaron{
        border: 1px solid red;
    }
    </style>
</head>

<body>
    <h2>通過before與after新增元素</h2>
    <button id="bt1">點選通過jQuery的before新增元素</button>
    <button id="bt2">點選通過jQuery的after新增元素</button>
    <div class="aaron">
        <p class="test1">測試before</p>
    </div>
    <div class="aaron">
        <p class="test2">測試after</p>
    </div>
    <script type="text/javascript">
    $("#bt1").on('click', function() {
        //在匹配test1元素集合中的每個元素前面插入p元素
        $(".test1").before('<p style="color:red">before,在匹配元素之前增加</p>', '<p style="color:red">多引數</p>')
    })
    </script>
    <script type="text/javascript">
    $("#bt2").on('click', function() {
        //在匹配test1元素集合中的每個元素後面插入p元素
        $(".test2").after('<p style="color:blue">after,在匹配元素之後增加</p>', '<p style="color:blue">多引數</p>')

    })
    </script>
</body>

注意點:

  • after向元素的後邊新增html程式碼,如果元素後面有元素了,那將後面的元素後移,然後將html程式碼插入
  • before向元素的前邊新增html程式碼,如果元素前面有元素了,那將前面的元素前移,然後將html程式碼插

2.DOM外部插入insertAfter()與insertBefore()

與內部插入處理一樣,jQuery由於內容目標的位置不同,然增加了2個新的方法insertAfter與insertBefore

選擇器 描述

insertAfter()

把元素插入到所有匹配的元素的後面

insertBefore()

把元素插入到所有匹配的元素的後面

  • .before()和.insertBefore()實現同樣的功能。主要的區別是語法——內容和目標的位置。 對於before()選擇表示式在函式前面,內容作為引數,而.insertBefore()剛好相反,內容在方法前面,它將被放在引數裡元素的前面
  • .after()和.insertAfter() 實現同樣的功能。主要的不同是語法——特別是(插入)內容和目標的位置。 對於after()選擇表示式在函式的前面,引數是將要插入的內容。對於 .insertAfter(), 剛好相反,內容在方法前面,它將被放在引數裡元素的後面
  • before、after與insertBefore。insertAfter的除了目標與位置的不同外,後面的不支援多引數處理
<!DOCTYPE html>
<html>

<head>
    <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
    <title></title>
    <script src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script>
    <style>
    .test1 {
        background: #bbffaa;
    }
    
    .test2 {
        background: yellow;
    }
    </style>
</head>

<body>
    <h2>通過insertBefore與insertAfter新增元素</h2>
    <button id="bt1">點選通過jQuery的insertBefore新增元素</button>
    <button id="bt2">點選通過jQuery的insertAfter新增元素</button>
    <div class="aaron">
        <p class="test1">測試insertBefore,不支援多引數</p>
    </div>
    <div class="aaron">
        <p class="test2">測試insertAfter,不支援多引數</p>
    </div>
    <script type="text/javascript">
    $("#bt1").on('click', function() {
        //在test1元素前後插入集合中每個匹配的元素
        //不支援多引數
        $('<p style="color:red">測試insertBefore方法增加</p>', '<p style="color:red">多引數</p>').insertBefore($(".test1"))
    })
    </script>
    <script type="text/javascript">
    $("#bt2").on('click', function() {
        //在test2元素前後插入集合中每個匹配的元素
        //不支援多引數
        $('<p style="color:red">測試insertAfter方法增加</p>', '<p style="color:red">多引數</p>').insertAfter($(".test2"))
    })
    </script>
</body>

</html>

注意事項:

  • insertAfter將JQuery封裝好的元素插入到指定元素的後面,如果元素後面有元素了,那將後面的元素後移,然後將JQuery物件插入;
  • insertBefore將JQuery封裝好的元素插入到指定元素的前面,如果元素前面有元素了,那將前面的元素前移,然後將JQuery物件插入;

相關文章