1. dom>documentElement>body>tagname

2.我们常用的节点标签。

  元素节点(标签)

  文本节点

  属性节点(标签里的属性)

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

1.代表元素节点  2.代表属性节点  3.代表文本节点

4.节点的获取

元素节点获取有很多方法

Document.getElementById()

Document.getElementsByClassName()

Document.getElementsByTagName()

Document.querySelector()

Document.querySelectorAll()

属性节点的获取

元素.attributes 获取元素身上所有属性构成的集合

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

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

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

文本节点

没有获取的方法,没有意思

5.获取元素的子节点

元素.childNodes 这个属性有兼容性 标准浏览器会获取文本节点

而低版本浏览器不会。所以建议使用 children这个属性

获取单个子节点

获取第一个子节点

标准下   元素.firstElementChild

非标准下   元素.firstChild

兼容写法

    var list=document.getElementById("list")

    var fist=listElementChild||list.fistChild

    console.log(fist)

获取最后一个子节点

  元素.lastElementChild  元素.lastChild

获取是一个兄弟节点

  元素.previousSibling  元素.prevElementSibling

获取下一个兄弟节点

  元素.nextSibling  元素.nextElementSibling

6.获取父节点

元素.parentNode 没有兼容性

元素.parentNode.parentNode

区分 offsetparent和parentNode

DOM2创建节点

1.生成节点的方法  document。createElement(“div”)

2.插入节点的方法  父节点.appendChild(新节点)

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

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

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

4.  删除元素节点  父元素.removerChild()

案例分析

  防留言板

 

兼容性

元素没有子节点,ie低版本读取不到,而标准浏览器会

因为标准浏览器会把文本节点当作子节点,而ie6-8不会

超链接a的属性href 分析

<a href="">点击会刷新页面,相当于向后台发送一个请求。

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

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

拓展

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

字符串拼接

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

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

DOM创建

  优点:每个都是独立的,不会影响原子元素事件

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

什么是DOM回流?

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

补充:

    提升页面性能优化

      1.多采用雪碧图

      2.防止超链接默认行为

      3.减少DOM回流

      4.减少向服务器发送请求次数  

                              发表人:晋飞翔

                               QQ:318080891

js节点的类型的更多相关文章

  1. js节点解析

    在JS中,每一个节点都有一个nodeType 属性,用于表明节点的类型.节点类型由在Node 类型中定义的下列12个数值常量来表示,任何节点类型必居其一: Node.ELEMENT_NODE(1); ...

  2. JS nodeType返回类型

    JS nodeType返回类型 前几天朋友正好问道 这个 js的nodeType是个什么概念(做浏览器底层的)正好遇到这篇文章可以向大家解释下 将HTML DOM中几个容易常用的属性做下记录: nod ...

  3. 关于snowflake算法生成的ID转换为JS的数字类型由于过大导致JS精度丢失的问题

    JS的数字类型目前支持的最大值为:9007199254740992,一旦数字超过这个值,JS将会丢失精度,导致前后端的值出现不一致. JAVA的Long类型的       最大值为:922337203 ...

  4. cocos2dx 如何获得节点的类型

    1. 需求:在所有子节点中得到是ui::Text类型的节点,并对其进行操作. 2. 解决方案:在根节点Node中有一个如下的函数: /** * Gets the description string. ...

  5. js节点操作实例

    写了一个简单的小例子来引用js实例 1. 初步节点操作: 2.兼容性节点操作: 3.节点的类型,名字: 4.使用setAttribute设置属性 5.节点复制操作: 6.删除和替换节点 如有错误,还望 ...

  6. js判断undefined类型

    js判断undefined类型 if (reValue== undefined){    alert("undefined");    }  发现判断不出来,最后查了下资料要用ty ...

  7. js DOM Node类型

    DOM(文档对象模型)是针对HTML和XML文档的一个API. DOM可以将任何HTML或XML文档描绘成一个由多层节点构成的.以特定节点为根节点的树形结构.节点分为12种不同的类型,每种类型分别表示 ...

  8. js 的强制 类型 转换cast, 伪对象?

    拼音输入法简单快捷, 但是重码多, 所以要看清了再选择, 不然会影响输入正确性和 心情的! js的类型 隐式 转换? 是指, 根据 表达式的操作符号 如if(), + , && , j ...

  9. js 节点 document html css 表单节点操作

    js 节点 document html css 表单节点操作 节点操作:访问.属性.创建 (1)节点的访问:firstChild.lastChild.childNodes.parentChild(父子 ...

随机推荐

  1. qrcode.php

    <!doctype html><html><head> <meta charset="UTF-8"/> <meta name= ...

  2. Openvswitch手册(4): Mirror

    这一节我们来分析Mirror Mirror就是配置一个bridge,将某些包发给指定的mirrored ports 对于包的选择: select_all,所有的包 select_dst_port se ...

  3. 【.NET Core项目实战-统一认证平台】第四章 网关篇-数据库存储配置(2)

    [.NET Core项目实战-统一认证平台]开篇及目录索引 上篇文章我们介绍了如何扩展Ocelot网关,并实现数据库存储,然后测试了网关的路由功能,一切都是那么顺利,但是有一个问题未解决,就是如果网关 ...

  4. 微信小程序中如何使用WebSocket实现长连接(含完整源码)

    本文由腾讯云技术团队原创,感谢作者的分享. 1.前言   微信小程序提供了一套在微信上运行小程序的解决方案,有比较完整的框架.组件以及 API,在这个平台上面的想象空间很大.腾讯云研究了一番之后,发现 ...

  5. 6.listview显示不用条目

    文件夹页面 布局只有一个listview,可以继承listactivity,这样少写一个布局文件 tool: * @param index 箱子的索引值 * @return * 对应的uri 或nul ...

  6. vi命令详解(转)

    vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令.由于对Unix及Linux系统的任何版本,vi编辑器是完全相 ...

  7. 神经网络架构pytorch-MSELoss损失函数

    MSELoss损失函数中文名字就是:均方损失函数,公式如下所示: 这里 loss, x, y 的维度是一样的,可以是向量或者矩阵,i 是下标. 很多的 loss 函数都有 size_average 和 ...

  8. CentOS7+Mono5.2.0.224 +Jexus5.8.3.0 布署 Asp.Net MVC (vs2017)

    背景: 比起大神我们只是差远了,只知道一味的找找看,找的资料不少,但真不知道哪一个是正确的. 之前一个文章也写了怎么安装 Jexus 但始终只有是html的静态页面可以asp.net 都不行(http ...

  9. Spring 事务传播实践分析

    事务管理是应用系统开发中必不可少的一部分.事物将若干的数据库操作作为一个整体控制,一起成功或一起失败.事物有以下特性 原子性:指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生.   ...

  10. 一个前端开发者换电脑的过程(git篇)

    一,安装git. 要安装git,首先得把它下载下来.去到git官网. 现在开始安装. 讲真,这些东西哪些要勾哪些不要勾我也不清楚,所以全部都按默认的来,一路next. 现在再打开vscode的终端,发 ...