一、关于节点

1、节点树状图

document>documentElement>body>tagName

2、节点类型

元素节点(标签)、文本节点(文本)、属性节点(标签属性)

3、document的属性nodeType的返回值是数字:

1:元素节点;2、属性节点;3、文本节点

4、获取节点的方法:

document.getElementById()

document.getElementsByClassName()

document.getElementsByTagName()

document.querySelector()

document.querySelectorAll()

5、属性节点的获取:

元素.attributes获取的是元素身上的所有属性构成的集合(数组),得到的数组里的值的某元素是  元素.attributes[1].value

元素.removeAttribute(“属性”)删除属性

元素.getAttributes(“属性名”)  获取属性名的方法

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

6、获取元素的子节点

元素.childNode 这个属性有兼容性

标准浏览器会获取到文本节点,低版本的浏览器不会获取到文本节点,所以使用children获取子节点

(1)获取第一个子节点

标准:元素.firstElementChild

非标准:元素.firstChild

兼容性写法:var list=documentById("list")

var first=list.firstElementChild||list.firstChild

console.log(first)

(2)获取最后一个子节点

标准:元素.lastElementChild

非标准:元素.lastChild

兼容性写法:var list=documentById("list")

var last=list.lasttElementChild||last.firstChild

console.log(last)

(3)获取上一个兄弟节点

标准:元素.previousElementSibling

非标准:元素.previousSibling

(4)获取下一个兄弟节点

标准:元素.nextElementSibling

非标准:元素.nextSibling

7、获取父节点

元素.parentNode  没有兼容性

8、区分offsetparent和parentNode的区别

offsetparent的父级,谁有position:relative;谁就是他的父级

二、DOM2动态创建节点

1、生成节点的方法

document.creatElement("div")

2、插入节点的方法

父元素.appendChild(新节点)

在父节点的后面插入新节点

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

父元素.insertBefore(新节点,谁前面插入)

新节点插入到指定节点前面

插入新节点的兼容性(浏览器的标准与非标准)

if(list.children[0]){

  list.insertBefore(li,list.children[0])

}else{

  list.appendChild(li)

}这种写法,是因为低版本浏览器不会吧文本节点当做子节点,所以insertBefor不起作用,要用appendChild追加一个元素

4、删除元素节点

父元素.removeChild()

补充知识点

1、关于超链接 a

<a href="javascript:;">取消刷新页面的功能

<a href="#s"> 锚点跳转,跳转到某一个id叫做S的位置上

<a href="">点击会刷新页面,会向服务器发送一次请求

2、字符串拼接和DOM创建都是渲染得方式

字符串拼接:

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

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

DOM创建:

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

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

3、DOM回流

页面渲染的时候,我们队html结构的增删查改时,浏览器会对所有的dom进行重新排列,这就是DOM回流,严重影响了浏览器的性能

关于document的节点;用Dom2创建节点;的更多相关文章

  1. JQuery_DOM 节点操作之创建节点、插入节点

    一.创建节点 为了使页面更加智能化,有时我们想动态的在html 结构页面添加一个元素标签,那么在插入之前首先要做的动作就是:创建节点 <script type="text/javasc ...

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

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

  3. js创建节点及其属性

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  4. Javascript 笔记与总结(2-10)删除节点,创建节点

    [删除节点] 步骤: ① 找到对象 ② 找到他的父对象 parentObj ③ parentObj.removeChild(子对象); [例] <!DOCTYPE html> <ht ...

  5. js添加创建节点和合并节点

    var _div = document.createElement("div"), //创建节点 txt1 = document.createTextNode("123& ...

  6. 1.javascript节点的操作 创建、添加、移除、移动、复制、插入(修改)

    (1)创建新节点 createDocumentFragment() //创建一个DOM片段 createElement() //创建一个具体的元素 createTextNode() //创建一个文本节 ...

  7. javascript 创建节点和新增节点

    createElement(tabName) 创建一个为tagName的新元素节点 ANode.appendChild(BNode)把B节点追加至A节点的末尾 insertBefore(ANode,B ...

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

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

  9. javascript创建节点的事件绑定

    javascript创建节点的事件绑定 timeupdate事件是<video>中用来返回视频播放进度的事件,绑定在<video>标签返回视频播放位置(每秒计). 现video ...

随机推荐

  1. Android Studio3.1.2编译时Java Compiler出错:Warning: Failed to parse host proxy3.bj...

    删除gradle.properties中的代理设置... #移除下面配置systemProp.http.proxyHost=proxy3.bj.petrochina systemProp.http.p ...

  2. 原生js上传文件,使用new FormData()

    当创建一个内容较多的表单,表单里面又有了文件上传,文件上传也需要表单提交,单一的上传文件很好操作: <form action="接口" enctype="multi ...

  3. 前端Web安全介绍及规避。。。

    本文转载自:https://jelon.top/posts/web-security/ 如果侵权,请及时告知. 一.跨站脚本攻击 (xss) 反射型跨站脚本攻击 攻击者会通过社会工程学手段,发送一个 ...

  4. nagiosQL访问时报错PHP message: PHP Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead

    nagiosQL安装环境: CentOS release 6.4 (Final) php-5.5.4 nagiosql_320 nginx version: nginx/1.2.3 安装一切正常,当访 ...

  5. VMwear安装Centos7超详细过程

    本篇文章主要介绍了VMware安装Centos7超详细过程(图文),具有一定的参考价值,感兴趣的小伙伴们可以参考一下 1.软硬件准备 软件:推荐使用VMwear,我用的是VMwear 12 镜像:Ce ...

  6. jenkins gradle 实践总结

    执行protoc 通过shell ,那么将gradle 中的proto 项目移除即可 安装 最新的idea 版本 ,并安装 最新kotlin 插件,通过http://plugins.jetbrains ...

  7. kubectl windows

    https://storage.googleapis.com/kubernetes-release/release/v1.10.3/bin/windows/amd64/kubectl.exe

  8. 数据类型&分支流程控制(2)

    1.数据类型 1.数据类型 局部变量:书写在方法中的变量: 全局变量:书写在类中,与方法平级的变量: -如果没有给变量赋初值 -全局变量会默认拥有一个初始值 -局部变量将没有初始值,这个时候不能使用这 ...

  9. Windows 2012设置允许单个用户连接多个会话的方法

    WINDOWS 2012 服务器默认只允许单个用户连接一个远程桌面会话,如果已有连接登陆,另外的连接再登陆会踢掉之前的连接.如果需要两个远程桌面同时连接 找到:HKEY_LOCAL_MACHINE\S ...

  10. php递归获取目录下所有文件

    <?php function getFileList($dir){ $dir=iconv("utf-8","gb2312",$dir); if ($hea ...