jquery节点操作
动态创建元素
$()函数的另外一个作用:动态创建元素
var $spanNode = $(“我是一个span元素”);
添加元素
append():在元素的最后一个子元素后面追加元素
作用:在被选元素内部的最后一个子元素(或内容)后面插入内容(存在或者创建出来的元素都可以),如果是页面中存在的元素,那么调用append()后,会把这个元素放到相应的目标元素里面去;但是,原来的这个元素,就不存在了。如果是给多个目标追加元素,那么方法的内部会复制多份这个元素,然后追加到多个目标里面去。
常用参数:htmlString 或者 jQuery对象
// 在$(selector)中追加$node
$(selector).append($node);
// 在$(selector)中追加div元素,参数为htmlString
$(selector).append('
不常用操作:
appendTo()
作用:同append(),区别是:把$(selector)追加到node中去:$(selector).appendTo(node);
prepend()
作用:在元素的第一个子元素前面追加内容或节点:$(selector).prepend(node);
after()
作用:在被选元素之后,作为兄弟元素插入内容或节点:$(selector).after(node);
before()
作用:在被选元素之前,作为兄弟元素插入内容或节点:$(selector).before(node);
//第一种:append(); 在调用者的所有子元素的最后面添加新元素
var newJQ1 = $("
我是append添加的li")
$("ul").append(newJQ1);
//第一种(下):appendTo(); 在调用者的所有子元素的最后面添加新元素
//被添加者和调用者与append位置想法
var newJQ11 = $("
我是appendTo添加的li")
newJQ11.appendTo($("ul"));
//第二种:prepend();在调用者的所有子元素的最前面添加新元素
var newJQ2 = $("
我是prepend添加的li")
$("ul").prepend(newJQ2);
//第二种(下):appendTo(); 在调用者的所有子元素的最前面添加新元素
//被添加者和调用者与prepend位置想法
var newJQ22 = $("
我是prependTo添加的li")
newJQ22.prependTo($("ul"));
//操作兄弟元素
//第三种:after();把某个元素以兄弟元素的形式添加到调用者之后
var newJQ3 = $("
我是after添加的li");
$("#box").after(newJQ3);
//第三种:before();把某个元素以兄弟元素的形式添加到调用者之前
var newJQ4 = $("
我是before添加的li");
$("#box").before(newJQ4);
html创建元素(补充)
作用:设置或返回所选元素的html内容(包括 HTML 标记)
设置内容的时候,如果是html标记,会动态创建元素,此时作用跟js里面的 innerHTML属性相同
// 动态创建元素
$(selector).html(‘创建元素’);
// 获取html内容
$(selector).html();
清空和删除元素
清空指定元素的所有子元素
没有参数
$(selector).empty();
$(selector).html("");
//把自己(包括所有内部元素)从文档中删除掉
$(selector).remove();
建议使用html("")方法来创建元素或者html("")清空元素。
复制元素
作用:复制匹配的元素
复制$(selector)所匹配到的元素
返回值为复制的新元素 $(selector).clone();
//获取按钮,赋值id为box的li,添加到ul的最后
$("button").click(function () {
//和参数无关,只能深层复制
var jqLI = $("#box").clone();
$("ul").append(jqLI);
});
如果本文有什么错误,欢迎留言指正,谢谢您!