06jQuery-04-DOM操作

jQuery既然是为了帮助你能从js的繁琐中解脱出来,自然在DOM操作上也有自己的一套。

1、修改Text和HTML

之前我们提到过,如果用JS的话,你要修改Text或者HTML需要用到其innerHTML和innerText属性,但是放在jQuery里面,你需要用到的是html()方法和text()方法,而且这两个方法很巧妙,如果你不传参,就是获取值;传参,就是更改值:

  1. <!-- HTML结构 -->
  2. <ul id="test-ul">
  3. <li class="js">JavaScript</li>
  4. <li name="book">Java &amp; JavaScript</li>
  5. </ul>
  6. //jQuery操作
  7. $(‘#test-ul li[name=book]‘).text(); // ‘Java & JavaScript‘
  8. $(‘#test-ul li[name=book]‘).html(); // ‘Java &amp; JavaScript‘

一个jQuery对象是可以包含0个或者多个DOM对象的,所以实际上它的方法会作用到每个DOM的节点上。

2、修改CSS

jQuery中可以使用css()方法对其CSS进行批量修改,比如高亮显示:

  1. $(‘#test-css li.dy>span‘).css(‘background-color‘, ‘#ffd351‘).css(‘color‘, ‘red‘);

同样地,如果css方法的第二个参数不传值,那么默认会返回现有属性:

  1. var div = $(‘#test-div‘);
  2. div.css(‘color‘); // ‘#000033‘, 获取CSS属性

3、新增class

  1. var div = $(‘#test-div‘);
  2. div.hasClass(‘highlight‘); // false, class是否包含highlight
  3. div.addClass(‘highlight‘); // 添加highlight这个class
  4. div.removeClass(‘highlight‘); // 删除highlight这个class

新增class属性可以很好地配合CSS用来进行效果展示:

  1. <!-- HTML结构 -->
  2. <style>
  3. .highlight {
  4. color: #dd1144;
  5. background-color: #ffd351;
  6. }
  7. </style>
  8. <div id="test-highlight-css">
  9. <ul>
  10. <li class="py"><span>Python</span></li>
  11. <li class="js"><span>JavaScript</span></li>
  12. <li class="sw"><span>Swift</span></li>
  13. <li class="hk"><span>Haskell</span></li>
  14. </ul>
  15. </div>
  16. //你可以这样使用jQuery配置css
  17. var div = $(‘#test-highlight-css‘);
  18. div.addClass(‘highlight‘);

4、隐藏和显示DOM

  1. var a = $(‘a[target=_blank]‘);
  2. a.hide(); // 隐藏
  3. a.show(); // 显示

5、获取DOM信息

  1. //获取DOM的高宽等信息
  2. // HTML文档大小:
  3. $(document).width(); // 800
  4. $(document).height(); // 3500
  5. //操作DOM节点的属性
  6. <div id="test-div" name="Test" start="1">...</div>
  7. var div = $(‘#test-div‘);
  8. div.attr(‘data‘); // undefined, 属性不存在
  9. div.attr(‘name‘); // ‘Test‘
  10. div.attr(‘name‘, ‘Hello‘); // div的name属性变为‘Hello‘
  11. div.removeAttr(‘name‘); // 删除name属性
  12. div.attr(‘name‘); // undefined
  13. //获取和设置对应value值
  14. input.val(); // ‘test‘
  15. input.val(‘[email protected]‘); // 文本框的内容已变为[email protected]

还要提一下的是,jQuery中还有一个方法叫做prop(),和attr()是类似的,但是对于某些可以没有值的属性来说,处理方式两者有所不同,例如:

  1. <input id="test-radio" type="radio" name="test" checked value="1">

以上代码中的checked,通常我们写作 checked="checked",但是在HTML5中是可以直接写 checked 这种方式的,两者对于其的处理方式是:

  1. var radio = $(‘#test-radio‘);
  2. radio.attr(‘checked‘); // ‘checked‘
  3. radio.prop(‘checked‘); // true

prop()的返回值更合理一些,不过,用 is() 方法判断更好:

  1. var radio = $(‘#test-radio‘);
  2. radio.is(‘:checked‘); // true

类似的属性还有selected,处理时最好用is(‘:selected‘)。

6、添加DOM

之前我们提到过,要添加DOM的话可以使用html()这种方式,原始简单粗暴。

实际上有个更好的方法 append(),它不仅像html()一样可以直接添加片段,还可以传入原始的DOM对象、jQuery对象和函数对象:

  1. // 创建DOM对象:
  2. var ps = document.createElement(‘li‘);
  3. ps.innerHTML = ‘<span>Pascal</span>‘;
  4. // 添加DOM对象:
  5. ul.append(ps);
  6. // 添加jQuery对象:
  7. ul.append($(‘#scheme‘));
  8. // 添加函数对象:
  9. ul.append(function (index, html) {
  10. return ‘<li><span>Language - ‘ + index + ‘</span></li>‘;
  11. });

append() 把DOM添加到最后,相应的 prepend() 把DOM添加到最前。

特别注意:如果要添加的DOM节点已经存在于HTML文档中,它会首先从文档移除,然后再添加,换句话说,对于已经存在于HTML中的DOM节点,可以使用append()方法达到移动的目的。

和append方法很类似的有个方法叫做 after(),其作用是在被选元素后插入指定的内容,仔细看看区别在于:

  • append() 是在被选元素的结束标签前面(即改被选元素的内部)插入指定内容
  • after() 是在被选元素的结束标签后面(即该被选元素的外部)插入指定的内容

也就是说,append() 实际上是类似于在某个节点中添加其子节点,而after()是某个节点之后添加兄弟节点,也就是说,after()是用于同级节点的,对应的,还有before()方法。

7、删除DOM

拿到对应的DOM节点的jQuery对象以后,直接调用 remove() 方法就可以删除了,如果该jQuery对象包含多个DOM节点,还可以实现批量删除。

时间: 2024-10-13 16:09:32

06jQuery-04-DOM操作的相关文章

jquery中的DOM操作

DOM操作分为:DOM核心.HTML-DOM.CSS-DOM 1.节点操作 查找 查找元素节点:jquery选择器 查找属性节点:attr("")方法,参数为要查询的属性的名字 创建 创建元素节点:$("html")方法,参数为HTML标记字符串,如:<p></p> 注意:(1)动态创建的新元素节点不会被自动添加到文档中,需要用其他方法插入文档中(2)创建元素时注意标签闭合,可以用$("<p></p>&quo

认识JQuery,JQuery的优势、语法、多库冲突、JS原生对象和JQuery对象之间相互转换和DOM操作,常用的方法

(一)认识JQuery  JQuery是一个JavaScript库,它通过封装原生的JavaScript函数得到一套定义好的方法    JQuery的主旨:以更少的代码,实现更多的功能 (二)JQuery的优势 1)可以像CSS一样访问和操作DOM 2)修改CSS控制页面外观 3)简化JS代码操作 4)事件代理更加容易 5)动画效果使用方便 6) Ajax技术更加完美 7)大量的基于Jquery的插件 8)可以自定义扩展功能插件 (三)JQuery的语法 格式:$(selector).actio

DOM操作表格

前面的话 表格table元素是HTML中最复杂的结构之一.要想创建表格,一般都必须涉及表示表格行.单元格.表头等方面的标签.由于涉及的标签多,因而使用核心DOM方法创建和修改表格往往都免不了要编写大量的代码.本文将详细介绍DOM操作表格的属性和方法 需求 要通过DOM实现下列格式的表格结构 <table border = "1" width = "100%">     <tbody>         <tr>           

zBase --轻量级DOM操作库

项目地址:ZengTianShengZ-github zBase-1.2.0 --v3 修复部分bug,添加AMD规范测试 zBase-1.1.0 --v2 对 v1 版本做了升级,优化DOM查找,简化API,提高代码可读性,支持模块化 支持 AMD & CommonJS zBase-1.0.0 --v1 没有任何依赖 轻量级的Dom操作库,封装一些常用的css选择器和事件操作等 Quick start $ npm install $ gulp scripts 使用npm安装 zBase: $

JQuery基本知识、选择器、事件、DOM操作、动画

1:基本选择器 <title></title> <script src="js/jquery-1.7.2.min.js"></script> </head> <body> <form id="form1" runat="server"> <div id="div1"> <a>aaaaa</a> <%--

jQuery学习之路(2)-DOM操作

▓▓▓▓▓▓ 大致介绍 jQuery作为JavaScript库,继承并发扬了JavaScript对DOM对象操作的特性,使开发人员能方便的操作DOM对象. ▓▓▓▓▓▓ jQuery中的DOM操作 看看DOM操作都有哪些 逐一来看 先写一份HTML代码,后面的代码将操作这份HTML代码 <p title="选择你最喜欢的水果">你最喜欢的水果?</p> <ul> <li title="苹果">苹果</li>

JavaScript常用原生DOM操作

最近,自己在投简历,找工作,在忙碌的复习当中,希望把有用的知识分享出去,是自己的成长,也可以给别人帮助. 今天给大家分享一些常用的原生的JavaScript DOM 操作. OK,那开始吧,那就开始吧O(∩_∩)O~~ 一.查看浏览器视口尺?   window.innerWidth/window.innerHeight(IE8以及IE8以下不能用  (′д` )-彡  )        document.documentElement.clientHeight/document.document

为什么说DOM操作很慢

原文转自:http://kb.cnblogs.com/page/534571/ 一直都听说DOM很慢,要尽量少的去操作DOM,于是就想进一步去探究下为什么大家都会这样说,在网上学习了一些资料,这边整理出来. 首先,DOM对象本身也是一个js对象,所以严格来说,并不是操作这个对象慢,而是说操作了这个对象后,会触发一些浏览器行为,比如布局(layout)和绘制(paint).下面主要先介绍下这些浏览器行为,阐述一个页面是怎么最终被呈现出来的,另外还会从代码的角度,来说明一些不好的实践以及一些优化方案

DOM操作优化

缓存DOM对象 JavaScript的DOM操作可以说是JavaScript最重要的功能,我们经常要根据用户的操作来动态的增加和删除元素,或是通过AJAX返回的数据动态生成元素.比如我们获得了一个很多元素的数组data[],需要将其每个值生成一个li元素插入到一个id为container的ul元素中,最简单(最慢)的方式是: var liNode, i, m; for (i = 0, m = data.length; i < m; i++) { liNode = document.createE

Jquery基础之DOM操作

 一.jQuery对象与Dom对象的区别 一直以来对于通过jQuery方式获取的对象使不能直接使用JavaScript的一些方法的,开始的时候不理解,现在此案知道,原来jQuery获得的对象并不和我们平时使用getElementById获得的对象是一样的对象.所以一些新手就很迷惑,为什么${”#Element”}不能直接innerHTML,这就是原因所在,解决方式请看下文. jQuery对象与dom对象的转换只有jquery对象才能使用jquery定义的方法.注意dom对象和jquery对象是有