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物件插入;