DOM操作分为3个方面:

  1. DOM Core    任何一种支持DOM Core的语言都可以使用它,比如getElementById就是DOM Core操作
  2. HTML-DOM  只能用来处理web文档
  3. CSS-DOM    针对CSS的操作

关于jQuery中的DOM操作

查找节点可以很轻易通过就jQuery选择器来找到,这里略过。

创建节点

var $myli= $('<li title="troy">troy123</li>');//创建jQuery对象
$("ul").append($myli);//将创建的DOM元素添加到ul中

插入节点

  • append()          向每个匹配的元素内部追加内容(上面已有示例)
  • appendTo()       将所匹配的元素追加到指定的元素中
    $myli.appendTo("ul");//改编自创建节点中的代码,效果一样
  • prepend()         向每个匹配的元素内部前置内容(与append相反,append是加在元素里子元素的后面)

  • prependTo()      将所匹配的元素追加到指定的元素中
  • after()              在每个匹配的元素之后插入内容,其实就是$("#liId").after($myli)的意思
  • insertAfter()      将所匹配的元素追加到指定的元素后面,同理,只不过不知道为什么没有写成afterTo,这样同一起来其实好理解一点
  • before()            在每个匹配的元素之前插入内容,其实就是$("#liId").before($myli)的意思
  • insertBefore()    将所匹配的元素追加到指定的元素前面,同理
    var $one_li=$("ul li:eq(1)");
    var $two_li=$("ul li:eq(2)");
    $two_li.insertBefore($one_li);//这样就实现了两个节点互换

删除节点

  • remove()   当某个节点调用remove方法后,该节点及其后代节点都会被删除。该方法的返回值是一个只想该被删除节点的引用。

    var $li= $("ul li:eq(0)").remove();
    $li.prependTo("ul");//结果没变化 $("ul li").remove("li[title=troy]");//选择性删除
  • detach()   和remove效果一样。但是用这个删除再像上面的例子那样插入的话,你会发现绑定在元素节点上的事件和附加的数据都还在,而remove的就不行。detach翻译为英文为拆分,似乎可以说明这就是为了先拿出来再插入的。
  • empty()   清空节点的所有后代节点

复制节点

  clone()方法进行复制节点,如果传参clone(true)就表示连节点的事件都会复制。

替换节点

我们当然可以先删后增来达到替换的效果,当然也有更简单的方法,那就是用replaceWith()和repalceAll();

包裹节点

$("strong").wrap("<b></b>");//每一个被匹配的<strong>元素都将被<b>包裹起来
$("strong").wrapAll("<b></b>");//所有被匹配到的<strong>元素被同一个<b>包裹起来
$("strong").wrapInner("<b></b>");//每一个被匹配到的<strong>元素的所有子元素都被一个<b>包裹起来

关于jQuery中的属性操作

var $myDiv=$("div");
var text=$myDiv.attr("title");//获取属性
$myDiv.attr("title","Troy123");//设置单个属性
$myDiv.attr({title:"Troy123",name:"Troy"});//设置单个属性
$myDiv.removeAttr("title");//删除属性

关于jQuery中的样式操作

  • attr("class")                       样式的获取和设置,$myDiv.attr("class")和$myDiv.attr("class","myClass")即可。
  • addClass("myClass")          追加样式。如果在不同的class中设置同一样式,那么后者覆盖前者。也就是说,此函数追加的样式中某一样式属性,如果在前面已经被某样式决定了,那么新的这个会覆盖旧的。
  • removeClass("myClass")     仅仅只删除myClass样式。而如果不要参数,直接$myDiv.removeClass(),那么将删除所有样式。
  • toggleClass("myClass")       当点击div时增加样式myclass,当再点击一次则移除,反复如此。
  • hasClass("myClass")           如果含有则返回true,如果没有则返回false。实际上在内部是用了$myDiv.is(".myClass")操作来实现。

设置和获取HTML、文本和值

  • html()        设置和获取某节点的html,玩法和attr()一样
  • text()         设置和获取某节点的文本内容,玩法同上
  • val()           设置和获取某节点的value属性,而val方法还能使select,checkbox和radio相应的选项被选中。
    $("#mySelect").val("选项2");//选中选项2
    $("#mulSelect").val(["选项2","选项3"]);//选中选项2,选项3
    $(":checkBox").val(["check2","check3"]);//选中value为check2和check3的多选框
    $(":radio").val(["radio1"]);//选中value为radio1的单选框
    //下面用attr方法实现
    $("#mySelect option:eq(1)").attr("selected",true);
    $("[value=radio2]:radio").attr("checked",true);

遍历节点

  • children()       该方法取得匹配元素的子元素集合,只取得子元素,不考虑后代元素
  • next()            取得匹配元素后面紧邻的同辈元素
  • prev()            取得匹配元素前面紧邻的同辈元素
  • siblings()       取得匹配元素前后所有的同辈元素
  • closest()        取得最近的匹配元素。先检查该元素是否匹配,不匹配就向上查父元素,有就返回匹配元素,无就返回空的jQuery对象
  • parent()        获取集合中每个匹配元素的父元素
  • parents()       获取集合中每个匹配元素的祖先元素,还可以加匹配参数
    $("#mydiv").parent();
    $("#mydiv").parents("div");
    $("#mydiv").closest("div");

CSS-DOM操作

css()方法无论是color属性,还是外部CSS导入,还是拼接在HTML的元素里,css方法都可以获取到属性style里的其他属性的值。

$("#mydiv").css("height");//获取样式高度值,可能为auto之类的
$("#mydiv").height();//获取真实高度值,必定为数值px

关于元素定位

  • offset()                             获取元素在当前视窗的相对偏移,其中返回的对象有两个属性:top和left。它只对可见元素有效。

    var myOffset=$("#mydiv").offset();
    var left=myOffset.left;
    var top=myOffset.top;
  • position()                          获取元素相对于最近的一个Position样式属性设置为relative或者absolute的祖先节点的相对偏移,也返回top和left。用法同上。
  • scrollTop()和scrollLeft()       获取和设置滚动条滑块距顶端和左侧的距离。
    $("#myTextArea").scrollTop();//获取距离
    $("#myTextArea").scrollTop(300);//设置距离

【jQuery基础学习】02 jQuery的DOM操作的更多相关文章

  1. jQuery基础学习(一)—jQuery初识

    一.jQuery概述 1.jQuery的优点      jQuery是一个优秀的JavaScript库,极大地简化了遍历HTML文档.操作DOM.处理事件.执行动画和开发Ajax的操作.它有以下几点优 ...

  2. jQuery基础学习3——jQuery库冲突

    默认情况下,jQuery用$作为自身的快捷方式. jQuery库在其他库之后导入 在其他库和jQuery库都被加载完毕后,可以在任何时候调用jQuery.noConflict()函数来将变量$的控制权 ...

  3. jQuery基础学习(三)—jQuery中的DOM操作

    一.查找节点      查找属性节点: 通过jQuery的选择器来完成.      操作属性节点: 调用jQuery对象的attr()来获取它的属性值.      操作文本节点: 通过text()方法 ...

  4. jQuery基础学习(二)—jQuery选择器

    一.jQuery基本选择器 1.CSS选择器     在学习jQuery选择器之前,先介绍一下之前学过的CSS选择器. 选择器 语法 描述 示例   标签选择器 E {                 ...

  5. jQuery基础学习4——jQuery容错性

    使用jQuery选择器不仅比使用传统的getElementById()和getElementsByTagName()函数简洁得多,而且还能避免某些错误. <script type="t ...

  6. JQuery基础学习总结

    JQuery基础学习总结 简单总结下JQuery: 一:事件 1.change事件 <!DOCTYPE html> <html lang="en"> < ...

  7. 【总结整理】JQuery基础学习---DOM篇

    前言: 先介绍下需要用到的浏览器提供的一些原生的方法(这里不处理低版本的IE兼容问题) 创建流程比较简单,大体如下: 创建节点(常见的:元素.属性和文本) 添加节点的一些属性 加入到文档中 流程中涉及 ...

  8. 【Java EE 学习 32 下】【JQuery】【JQuey中的DOM操作】

    一.JQuery中的DOM操作. 什么是DOM:DOM是一中和浏览器.平台.语言无关的接口,使用该接口可以轻松访问页面中所有的标准组件.DOM简称文档对象模型,是Document Oject Mode ...

  9. 【jQuery基础学习】04 jQuery中的表格操作及cookie插件的使用

    这章本来准备写成jQuery的表单操作和表格操作的. 然而昨天吧jQuery的表单操作看完,发现全部在炒之前章节的剩饭,所以就没写出来. 那么今天就来看看表格吧. 因为平常做的都是公司的内部管理系统, ...

随机推荐

  1. Windows7 网上邻居设置

    1.运行gpedit.msc进入组策略:Windows设置---安全配置---本地策略---安全选项---网络访问:本地账户的共享和安全模型(设为仅来宾-对本地用户进行身份认证)---网络访问:不允许 ...

  2. c# -- 对象销毁和垃圾回收

    有些对象需要显示地销毁代码来释放资源,比如打开的文件资源,锁,操作系统句柄和非托管对象.在.NET中,这就是所谓的对象销毁,它通过IDisposal接口来实现.不再使用的对象所占用的内存管理,必须在某 ...

  3. ubuntu-14.04.x-desktop-amd64.iso:安装Oracle11gR2

    特点: 使用ubuntu-14.04.x-desktop-amd64.iso liveCD模式 + Casper-rw 本地文件 不降级默认的gcc版本,(liveCD 自带默认为 gcc 4.8): ...

  4. php中并发读写文件冲突的解决方案(文件锁应用示例)

    PHP(外文名: Hypertext Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言.语法吸收了C语言.Java和Perl的特点,入门门槛较低,易于学习,使用广泛,主要适 ...

  5. saiku之行速度优化(三)

    经历了前两轮优化之后,saiku由不可使用,优化到可以使用,不过在分析大量日志数据的时候,还有顿卡的感觉!继续观察背后执行的Sql,决定将注意力关注到索引上面! 日志的主要使用场景是:固定日期维度的数 ...

  6. STAF自动化测试框架

    STAF自动化测试框架介绍 http://baike.baidu.com/link?url=9oPZN3JntRakidI7xizqCbyGRISMvCKGfXHBB_WH7OAkKjAKZjq88q ...

  7. 如果你遇到,在IntelliJ IDEA里Ctrl+Alt+方向键用不了

    在idea中使用ctrl+b跟踪进入函数之后,每次返回都不知道用什么快捷键,在idea中使用ctrl+alt+方向键首先会出现与win7屏幕方向的快捷键冲突,右键桌面,选择图形属性,将win7的快捷键 ...

  8. Windows下gvim的快捷键--“冒号+w+回车”真的很累人

    发现Windows下的gvim支持Ctrl+S保存,Ctrl+A全选,Ctrl+C复制,Ctrl+V粘贴,Ctrl+Z撤销 不过Ctrl+X貌似不太正常(可以剪切,但是不能粘贴) 可能要在安装目录下的 ...

  9. c# double保留2位小数

    / (endIndex - startIndex); interval = Math.Round(interval , );

  10. Tomcat自动部署

    在Tomcat的server.xml配置文件中部署 1.在Tomcat下,找到conf文件下的server.xml,打开. 2.在<Host>和</host>之间加上如下代码: ...