本文摘自PHP中文网,作者藏色散人,侵删。
jquery dom是指文档对象模型即Document Object Model,是W3C国际组织的一套Web标准,DOM可被JavaScript用来读取、改变HTML、XHTML以及XML文档。
推荐:《jquery视频教程》
什么是DOM?
要改变页面的某个东西,JavaScript 就需要获得对 HTML 文档中所有元素进行访问的入口。这个入口,连同对 HTML 元素进行添加、移动、改变或移除的方法和属性,都是通过文档对象模型来获得的(DOM)。
在 1998 年,W3C 发布了第一版的 DOM 规范。这个规范允许访问和操作 HTML 页面中的每一个单独的元素。
所有的浏览器都执行了这个标准,因此,DOM 的兼容性问题也几乎难觅踪影了。 DOM 可被 JavaScript 用来读取、改变 HTML、XHTML 以及 XML 文档
HTML-DOM
HTML-DOM 在使用JavaScript和DOM为HTML文件编写脚本,有许多专属于HTML-DOM的属性. HTML-DOM的出现甚至比DOM Core还要早,它提供一些更简明的符号来描述各种HTML元素的属性。
例如: 使用HTML-DOM来获取表单对象 的方法: document.forms
CSS-DOM
CSS-DOM是针对CSS的操作。在JavaScript中,CSS-DOM技术的主要作用是获取和设置style对象的各种属性。通过改变style对象的各种属性,可以使网页呈现出各种不同的效果
设置某个元素style对象字体颜色的方法: elements.style.color = “red”;
JQuery中的DOM操作
查找节点
元素可以通过text()方法读取其中的html内容,相当于DOM的innerHTML属性
1 2 3 4 5 6 7 | $( function (){
var $para = $( "p" );
var $li = $( "ul li:eq(1)" );
var p_txt = $para .attr( "title" );
var ul_txt = $li .attr( "title" );
var li_txt = $li .text();
});
|
插入节点
删除节点:
需要注意的是,在删除元素时,如果当前元素包括子元素,会一同删除,并且在删除元素时会返回一个当前被删除元素的引用,可以在以后再使用这些元素。
1 2 3 4 5 6 7 8 | $( function (){
var $li = $( "ul li:eq(1)" ).remove();
$li .appendTo(“ul”);
});
$( function (){
$( "ul li" ).remove( "li[title!=菠萝]" );
});
|
清空元素:
清空了ul 中的第二个li中的所有后代节点。注意:empty和remove的区别,empty清空元素内的后代节点,元素本身保留。
1 2 3 | $( function (){
$( "ul li:eq(1)" ). empty ();
});
|
复制节点:
这个复制出来的新元素不具有任何的行为,也就是当点击克隆出来的新元素的时没有前面设置的点击事件,如果需要可以在clone方法中传递一个参数clone(true),表示复制元素时同时复制元素中的所绑定的事件。
1 2 3 4 5 | $( function (){
$( "ul li" ).click( function (){
$(this). clone ().appendTo( "ul" );
})
});
|
替换节点:
1 2 3 4 | $( function (){
$( "p" ).replaceWith( "<strong>你最不喜欢的水果是?</strong>" );
});
|
包裹节点 :wrap ,wrapAll ,wrapInner
1 2 3 | $( function (){
$(“span”).wrap(“<strong></strong>”);
})
|
运行结果代码:
1 2 | <strong><span>选择你最喜欢的水果</span></strong>
$( "span" ).wrapAll( "<strong></strong>" );
|
执行后结果
1 2 3 4 5 6 | <strong>
<span>选择你最喜欢的水果</span>
<span>选择你最喜欢的水果</span>
</strong>
<span>选择你最喜欢的水果</span>
$( "span" ).wrapInner ( "<strong></strong>" );
|
执行后结果
1 | <span><strong>选择你最喜欢的水果</strong></span>
|
属性操作
1 2 3 4 5 6 7 8 9 10 11 12 | var p_txt = $( "p" ).attr(“title”);
$( function (){
$( "a:contains('link')" ).attr( "href" ,“index.html");
})
$( "a:contains('link')" ).attr({ "href" :“index.html "," title ":" test"});
attr({ "属性1" : "值1" , "属性2" : "值2" , "属性3" : "值3" })
$(“a”).removeAttr(“title”);
|
注意:jQuery中有很多函数同时实现取值get,和设置set,包括html(),text(),height(),width(), val(),css()等.
样式操作
1 2 3 4 | var p_class = $(“p”).attr(“ class ”);
$(“p”).attr(“ class ”,”high”);
|
注意:使用属性方式设置样式会替换掉原有的样式,如果想实现追加效果可以使用addClass
追加样式:
样式:
1 2 3 4 | <style type= "text/css" >
.high {font-weight:bold; color:red; }
.another{font-style:italic; color:blue;}
</style>
|
html:
1 2 3 4 | <p title= "选择你最喜欢的水果" class = "high" >选择你最喜欢的水果</p>
jQuery:
$(“p”).addClass(“another”);
|
注意:样式设置遵循两条规则 如果个一个元素添加了多个class值时,就相当于合并它们的样式。 如果不同的class设置了同一样式属性,则后者覆盖前者。
移除样式
1 2 3 4 5 6 7 | $(“p”).removeClass(“high”);
$(“p”).removeClass(“high”).removeClass(“another”);
$(“p”).removeClass();
Toggle
|
toggle事件控制样式设置和取消,第一次点击时执行toggle事件定义中的第一个函数块,当第二次点击时运行toggle事件定义中的第二个函数块,以此类推。
1 2 3 4 5 6 7 | $( function (){
$(“p”).toggle( function (){
$(this).addClass(“another”);
}, function (){
$(this).removeClass(“another”);
})
})
|
toggleClass 方法有类似的功能
当超链接点击时执行代码设置样式,这时设置样式时会自动判断,如果当前样式不在对应元素上则添加样式,如果在当前元素上则删除样式。
1 2 3 4 5 6 | $( function (){
$(“#link”).click( function (){
$(“p”).toggleClass(“another”);
return false;
})
})
|
设置和获取 括号里面没有就是取,有就是设置
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | --HTML文本值
var p_html = $(“p”).html();
$(“p”).html(“<strong>选择你最喜欢的水果</strong>”);
--text()方法 文本
var p_text = $(“p”).text();
$(“p”).text(“选择你最喜欢的水果”);
--val()方法 value
var txt_value = $(this).val();
$(this).val( "" );
|
遍历节点
CSS-DOM
1 2 3 4 5 6 7 8 | $(“p”).css(color);
$(“p”).css(“color”,”red”);
$(“p”).css({“color”:”red”,”background”:”#003333”});
$(“p”).css(“opacity”,”0.5”);
|
以上就是jquery dom是什么的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
jQuery如何删除元素
jQuery如何实现一键全选
jQuery css怎么设置高度
jQuery wrap()方法是什么意思
vue.js支持jQuery吗?
jQuery怎么样判断文件是否存在
jQuery中怎么修改css样式
jQuery和ajax的区别是什么
jQuery怎么遍历节点
jQuery如何按name属性选择元素
更多相关阅读请进入《jQuery》频道 >>
人民邮电出版社
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者
转载请注明出处:木庄网络博客 » jquery dom是什么