DOM:Document Object Model  文档对象模型

文档:html页面

文档对象:页面中元素

文档对象模型:定义  为了能够让程序(js)去操作页面中的元素

DOM会把文档看作是一棵树,同时定义了很多方法来操作这颗树中的每一个元素(节点)

DOM节点

如:

getElementById

getElementByTagName

document

document.body

...

//***************************************

childNodes : 只读属性  子节点列表集合

  标准下:包含了文本和元素类型的节点,也包含非法嵌套的子节点

  非标准下:只包含元素类型的节点,ie7以下不会包含非法嵌套的子节点

  childNodes只包含一级子节点,不包含后辈孙级以下的节点

  DOM节点类型有12种,比较重要的有:

元素类型 nodeType
元素节点 1
属性节点 2
文本节点 3
注释节点 8
文档节点 9

attributes:只读属性  属性列表集合

children:只读属性  子节点列表集合

  标准下:只包含元素类型的节点

  非标准下:只包含元素类型的节点

firstChild:只读属性  第一个子节点

  标准下:firstChild会包含文本类型的节点

  非标准下:只包含元素节点

firstElementChild:只读属性  第一个子节点

  标准下获取第一个元素类型的子节点

  非标准下不支持这个属性

lastChild || lastElementChild 最后一个子节点

nextSibling || nextElementSibling 下一个兄弟节点

previousSibling || previousElementSibling  上一个兄弟节点

parentNode:只读属性  当前节点的父级节点

  标准下和非标准下都正常!

offsetParent:只读属性  离当前元素最近的一个有定位属性的父节点

  如果没有定位父级,默认是body

  ie7以下,如果当前元素没有定位默认是body,如果有定位则是html

  ie7以下,如果当前元素的某个父级触发了layout,那么offsetParent就会被指向到触发了layout特性的父节点上

offsetLeft[Top]:只读属性  当前元素到定位父级的距离(偏移值),即到当前元素的offsetParent的距离

  如果没有定位父级
    offsetParent -> body
    offsetLeft -> html  (ie7以下有可能)

  如果有定位父级
    ie7以下:如果自己没有定位,那么offsetLeft[Top]是到body的距离
        如果自己有定位,那么就是到定位父级的距离
    其他:到定位父级的距离

width  height   //**不存在兼容问题

  style.width:样式宽

  clientWidth:可视区宽 (包括padding)

  offsetWidth:占位宽(包括padding和border)

//**************************

操作元素属性的方式:

元素.属性名    //可赋值,可获取值

元素[属性名]    //可赋值,可获取值

  两者区别:单属性名是变量的时候,不能通过“.”的方式,必须要用“[]”

getAttribute(属性名); 方法,获取指定元素的指定属性的值

setAttribute(属性名,属性值);方法,给指定元素指定的属性设置值

removeAttribute(属性名称); 方法,移除指定元素的指定属性

/**

  1、用.和[]的形式无法操作元素的自定义属性

     getAttribute可以操作元素的自定义属性 (无兼容问题)

  2、getAttribute可以获取元素属性实际的值,如img的src属性值,获取的是设定的实实在在的值(ie7以下还是会返回资源    的绝对路径)

**/

document.createElement(标签名称); 创建元素

父级.removeChild(要删除的元素); 删除元素

父级.appendChild(要添加的元素) 方法 追加子元素

父级.insertBefore(新的元素,被插入的元素) 方法   在指定元素前面插入一个新元素

  在ie下如果第二个参数的节点不存在,会报错

  在其他标准浏览器下如果第二个参数的节点不存在,则会以appendChild的形式进行添加

父级.replaceChild(新节点,被替换节点) 替换子节点

/*

  appendChild,insertBefore,replaceChild都可以操作动态创建出来的节点,也可以操作已有节点

*/

js——DOM操作(一)的更多相关文章

  1. JS DOM操作(创建、遍历、获取、操作、删除节点)

    创建节点 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="u ...

  2. js dom 操作

    JS的DOM操作   1DOM是文档对象模型,这种模型为树模型:文档是指标签文档,对象是指文档中每个元素:模型是指抽象化的东西. 2间隔与延迟间隔执行一段代码(函数):window.setInterv ...

  3. JS—DOM操作

    节点分为三类: 1.元素节点:标签<div></div> 2.文本节点:标签内的纯文本. 3.属性节点:标签内的属性,id或class 查找元素: getElementById ...

  4. JS DOM操作 函数 事件 阻止事件冒泡

    一 函数 1.字符串函数 s.tolowerCase( ):    -- 变小写 s.toupperCase( ):   -- 变大写 s.substr( 2 , 8 ):     -- 截取     ...

  5. JS DOM操作(五) Window.docunment对象——操作元素

    定位: var a = document.getElementByIt( "id" ) 同辈元素 var b = a.nextSibling;            -- 找 a ...

  6. JS DOM操作(二) Window.docunment对象——操作样式

    一 对元素的定位 在 js 中可以利用 id.class.name.标签名进行元素的定位 id.class  用在客户端 name  用在服务端 用 id 定位                  -- ...

  7. JS DOM操作(一) 对页面的操作

    DOM ——文档对象模型(Document Object Model)是表示和处理一个HTML或XML文档的常用方法. 在网页上,组织页面(或文档)的对象被组织在一个树形结构中,用来表示文档中对象的标 ...

  8. js dom 操作技巧

    1.创建元素 创建元素:document.createElement() 使用document.createElement()可以创建新元素.这个方法只接受一个参数,即要创建元素的标签名.这个标签名在 ...

  9. js DOM操作练习

    1.有如下html,如果用js获得被选中的option的text描述(非value)<select id="select_id">    <option vlue ...

随机推荐

  1. hdu 5621 KK's Point(数学,推理题)

    题解: 在圆上点三个点时,除圆上三个交点外,圆内没有交点:在圆上点四个点时,除圆上四个交点外,圆内出现了一个交点,因此,在N个点中每四个点便可以在圆内产生一个交点,因此N个点在圆内形成的点的个数为CN ...

  2. Java程序员应该知道的10个面向对象理论

    英文原文:10-object-oriented-design-principles 面向对象理论是面向对象编程的核心,但是我发现大部分 Java 程序员热衷于像单例模式.装饰者模式或观察者模式这样的设 ...

  3. CSS3无前缀脚本prefixfree.js与Animatable使用

    现代浏览器基本支持CSS3,但是一些旧版本的浏览器还是需要添加前缀的.像box-shadow, border-radius这类属性,目前较新版本的浏览器都是不需要前缀的(包括IE9),但是,有些CSS ...

  4. 【转】Android的线程使用来更新UI----Thread、Handler、Looper、TimerTask

    方法一:(java习惯,在android不推荐使用) 刚刚开始接触android线程编程的时候,习惯好像java一样,试图用下面的代码解决问题 new Thread( new Runnable() { ...

  5. oracle 定义数据完整性

    1. 定义主键约束 1.1 在创建表时定义主键约束 create table student(name varchar2(8),studentid varchar2(10) primary key,s ...

  6. 取得网站的IP 地址

    select utl_inaddr.get_host_address('smtp.163.com') ipaddress from dual;

  7. 蜗牛爱课 -- iOS 设置UIButton的字体的大小、显示位置、大小

    /设置按钮上的自体的大小 //[btn setFont: [UIFont systemFontSize: 14.0]];    //这种可以用来设置字体的大小,但是可能会在将来的SDK版本中去除改方法 ...

  8. Ark组件设计随想(一)

    Ark组件是L.Skyler自工作以来不断积累和优化的快速开发胶水架. Ark的目标是帮助开发人员简单快速的开始一个新的项目并且尽可能的复用已有功能.让项目开发不受一些基础组件开发影响. Ark定义了 ...

  9. HDU1789(Doing Homework again)题解

    HDU1789(Doing Homework again)题解 以防万一,题目原文和链接均附在文末.那么先是题目分析: [一句话题意] 给定任务分数和其截止日期,每日可完成一任务,输出当罚分尽可能小时 ...

  10. android AsyncTask 的使用(转载)

    1 ) AsyncTask实现的原理,和适用的优缺点 AsyncTask,是android提供的轻量级的异步类,可以直接继承AsyncTask,在类中实现异步操作,并提供接口反馈当前异步执行的程度(可 ...