一、Dom获取

  1、全称:Document     Object     Model  文档对象模型

  2、我们常用的节点类型

    元素(标签)节点、文本节点、属性节点(也就是标签里的属性)、

  3、document有个属性叫nodeType返回的是数字

    1:代表元素节点

    2:代表属性节点

    3:代表文本节点

  4、节点的获取

    元素节点的获取方法

      Document.getElementById()

      Document.getElementsByClassName()

      Document.getElementsByTagName()

      Document.querySelector()

      Document.querySelectorAll()

    属性节点的获取方法

      元素 . getAttribute("属性名")    获取属性值的方法

      元素 . attribuites           获取元素身上所有属性构成的集合(数组)

      元素 . attribute [ 索引 ] . value     获取元素里面的值

       元素 . setAttribute("属性名","属性值")  给元素设置属性和属性值

       元素 . remove("属性")        删除元素

    文本节点没有获取的方法,没有意义

  5、获取元素的子节点

    元素 . childNodes  这个属性有兼容性,标准浏览器回获取文本节点,而低版本的浏览器不会,所以建议children属性

    获取单个子节点:具有兼容问题

      获取第一个子节点:

        标准下:元素 . firstElementchild

        非标准下:元素 . firstchild

      获取最后一个子节点:

        标准下:元素 .lastElementchild

        非标准下:元素 . lastchild

      获取上一个兄弟节点:

        标准下:元素 . previousElementsibling

        非标准下:元素 . previoussibling

      获取上一个兄弟节点:

        标准下:元素 . nextElementchild

        非标准下:元素 . nextchild

      解决兼容性问题:

        拿获取第一个子节点为列:

          var    list=document . getElementById("list")

          var   ss=list . firstElementchild ||  list . firstchild

  6、获取父节点

      元素 . parentNode     没有兼容性

二、Dom 动态创建节点

  1、生成节点的方法:

    document . createElement("div")

  2、插入节点的方法:

    父节点 . appendChild("新节点")

  3、在指定的位置插入节点

    父节点 . inserBefore(新节点,谁的前面)    将元素插入指定节点的前面

  4、删除节点

    父节点 . removechild()   

 三、拓展

  字符串中的拼接和Dom创建都是渲染的方试

  字符串:

    优点:简单,可以处理数据,层次感比较强

    缺点:字符串拼接会影响到原来子元素的事件

  Dom创建:

    优点:是一个独立的个体,不会影响到原来的元素

    缺点:处理数据量过大会比较麻烦,会造成Dom回流

  Dom回流:

    页面渲染时,我们对html结构简单的增删查改时,浏览器会对所有的dom重新排序,这就是Dom回流,严重影响浏览器的性能

  提升页面性能优化:

    1、多采用雪碧图

    2、阻止超链接的默认行为

    3、减少DOM回流

    4、减少向服务器请求次数

Dom 获取、Dom动态创建节点的更多相关文章

  1. 11-15 dom 动态创建节点

    1.生成节点的方法  document.createElement(“div”) 2.插入节点的方法   父元素.appendChild(新节点) 在父节点中的子节点后面插入新的节点 3.在指定的位置 ...

  2. delphi dom动态创建节点方法

    在一次测试demo中 需要动态的创建xml节点并添加,实现方法如下: var NewItem:IXMLDOMElement; NewItem:=ConfigDoc.createElement('ite ...

  3. HTML中javascript使用dom获取dom节点范例

    <!-- HTML结构 --> <div id="test-div"> <div class="c-red"> <p ...

  4. js···DOM2动态创建节点

    1.生成节点的方法  document.createElement(“div”) 2.插入节点的方法   父元素.appendChild(新节点) 在父节点中的子节点后面插入新的节点 3.在指定的位置 ...

  5. jquery动态创建节点

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. DOM创建节点

    1.DOM--document object model 常用的节点类型: 元素节点:(标签) 属性节点:(标签里的属性) 文本节点:(文本节点) 2,document有个属性叫nodetype,返回 ...

  7. 关于document的节点;用Dom2创建节点;

    一.关于节点 1.节点树状图 document>documentElement>body>tagName 2.节点类型 元素节点(标签).文本节点(文本).属性节点(标签属性) 3. ...

  8. FineUIMvc随笔 - 动态创建表格列

    声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版. 用户需求 用户希望实现动态创建表格列,在 WebForms 中,我们通过在 Page_Init 中创建列来实现: 但是在 MVC ...

  9. FineUIMvc随笔(1)动态创建表格列

    声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版. <FineUIMvc随笔>目录 FineUIMvc随笔(1)动态创建表格列 FineUIMvc随笔(2)怎样在控件中 ...

随机推荐

  1. ubuntu16.04和服务器 caffe 安装

    在centos6.X上安装caffe 0.编译安装gcc4.8.5 由于centos6.x中的gcc版本老旧,不支持c++11所以要安装gcc4.8.5,以下是安装教程.参考CentOS 6.4 编译 ...

  2. 织梦dedecms首页/列表页/内容页调用tag的方法(未测试)

    织梦dedecms首页/列表页/内容页调用tag的方法 在网站中tag是网站搜索相关文章的联系之一,也可以有专门的tag页面,在不同的页面也可以调用tag,而不是只有在首页和列表页才可以调用tag,这 ...

  3. linux初级学习笔记一:linux操作系统及常用命令,及如何获取命令的使用帮助!(视频序号:02_1,2)

    本节学习的命令:ls,cd,type,pwd, printenv, hash, date, clock, man, hwclock, info, cal, echo, printf, file! 本节 ...

  4. Silverlight 2中实现文件上传和电子邮件发送

    Silverlight 2中实现文件上传和电子邮件发送 [收藏此页] [打印]   作者:IT168 TerryLee  2008-05-30 内容导航: 使用Web Service上传文件   [I ...

  5. Android中的ProgressBar的android:indeterminate

    不明确(false)就是滚动条的当前值自动在最小到最大值之间来回移动,形成这样一个动画效果,这个只是告诉别人“我正在工作”,但不能提示工作进度到哪个阶段.主要是在进行一些无法确定操作时间的任务时作为提 ...

  6. org.apache.hadoop.hbase.NotServingRegionException: Region is not online 错误

    当遇到如下错误的时候 可能以为是regionserver 挂掉或者其他原因导致连接不上regionserver  但后面提示了Hbase 表statistic_login 具体信息 Thu Jan 1 ...

  7. Linux 命令行命令及参数辨异

    1. 软链接与硬链接 ln -s 源文件 目标文件 当我们需要在不同的目录,用到相同的文件时,我们不需要在每一个需要的目录下都放一个必须相同的文件,我们只要在某个固定的目录,放上该文件,然后在其它的目 ...

  8. NSError分析

    在iOS开发中,NSError的使用非常常见,使用也比较简单,也正因为简单,所以对这一部分知识不甚注重.但是近期在做app底层网络封装时发现了一些问题.我使用的网络框架是AFNetworking,AF ...

  9. 「LuoguP1238」 走迷宫

    Description 有一个m*n格的迷宫(表示有m行.n列),其中有可走的也有不可走的,如果用1表示可以走,0表示不可以走,文件读入这m*n个数据和起始点.结束点(起始点和结束点都是用两个数据来描 ...

  10. NOIP前的水题记录

    CF147B Smile House 二分+矩阵快速幂,注意一下储存矩阵相乘结果的矩阵,初始化时,a[i][i]=-inf(而其他都可以a[i][i]=0,为了保证答案的可二分性). CF715B C ...