一、JavaScript的三个重要组成部分

(1)ECMAScript(欧洲计算机制造商协会)

  制定JS的规范

(2)DOM(文档对象模型)重点学习对象

  处理网页内容的方法和接口

(3)BOM(浏览器对象模型)  存在兼容性问题

  与浏览器进行交互的方法和接口

1、DOM定义

  为js操作html元素而制定的规范,DOM树如下图

2、节点

  整个文档是一个文档节点

  每一个标签是一个元素节点

  标签中的文字是一个文字节点

  标签中的属性是一个属性节点

3、访问节点的方法

  getElementById();      获取id对应的元素节点  只有他是的返回值是唯一的,也就是说是一个变量,其余返回值全是数组,切记!

  getElementsByTagName();  获取标签数组  例如 :div   ul   a

  getElementsByName();    获取name对应的元素节点数组

  getElementsByClassName();获取class对应的元素节点数组    有兼容性问题,所以我们要自己封装一个获取class类的方法

  getElementById().getElementsByClassName();  获取某个ID下的class数组

  getElementById().getElementsByTagName();  获取某个id下的标签数组

4、封装自己的获取class类的方法

  原理:其实就是遍历文档中的所有标签,从这些标签中找到与自己class类一样的类。

  兼容性问题:就是getElementsByClassName();有兼容性问题,但是我们在高级浏览器中还是可以用的

  代码:

function getClass(classname) {
//如果浏览器支持这个方法,我们还是不要浪费他的高性能,尽量使用
if (document.getElementsByClassName) {
return document.getElementsByClassName(classname);
}
//如果不能支持
var arr = [];
var dom = document.getElementsByTagName("*");
for (var i = 0; i < dom.length; i++) {
var txt = [];
txt = dom[i].className.split(" ");
for (var j = 0; j < txt.length; j++) {
if (txt[j] == classname) {
arr.push(dom[i]);
}
}
}
return arr;
}

5、访问关系(这样的好处是能省去起名的痛苦)

  (1)父亲点

<script>
window.onload = function(){
var x = document.getElementById("x");
x.onclick = function(){
this.parentNode.style.display = "none";
//关掉的是他的 父亲 this.parentNode 这种方法还是比较厉害的,能节省一个盒子的id起名
      } 
  }
</script>

  (2)兄弟节点  

    nextSibling  下一个亲兄弟    亲的       IE 678 认识

    nextElementSibling   其他浏览器认识的

    previousSibling   同理  上一个兄弟

    previousElementSibling

   (3)子节点(这个容易报错  不怎么用)    

    firstChild    第一个孩子  ie678

    firstElementChild  第一个孩子   正常浏览器

    var one.firstElementChild || one.firstChild;

    lastChild

    lastElementChild

  (4)孩子节点(这个比较常用,虽然有点小问题)

    childNodes    选出全部的孩子——元素节点   文本节点   属性节点

    childNodes:它是标准属性,它返回指定元素的子元素集合,包括HTML节点,所有属性,文本节点     (嫡出)

    火狐 谷歌等高本版会把换行也看做是子节点

    利用  nodeType == 1   时才是元素节点     来获取元素节点

    

    (重要)children   选取所有的孩子——只有元素节点;这个更好 跟喜欢它  。 (庶出)   但是ie 678  包含 注释节点     这个要避免开。

6、DOM节点操作部分(非常重要)

  创建节点   插入节点   删除节点  克隆节点

             谁要添加   谁要删除  谁要克隆

  (1)创建节点(是插入的根基)

    document.createElement(类型);

    举例:var div = document.creatElement(“li”);   生成一个新的  li 标签

  (2)插入节点

    ①appendChild()  默认插入到最后面

      

    ②insertBefore(插入节点,参照节点)

      如果第二个参数不为空,则将插入节点放到参照节点的前面;如果第二个参数  为 null  则 默认这新生成的盒子放到最后面。

  (3)删除节点

    removeChild()

  (4)克隆节点

    cloneNode(bool);   参数为false,浅层复制,只复制父亲,不复制儿子;  参数为true时,深层复制,包括儿子一起复制。

JS操作DOM对象——JS基础知识(四)的更多相关文章

  1. js操作DOM对象

    js操作DOM对象  (Document Object Model)文档对象模型 nodeType返回值 1:元素节点 2:属性节点 3:文本节点 8:注释节点 9: 文档节点 nodeName 节点 ...

  2. 【JavaScript实用技巧(二)】Js操作DOM(由问题引发的文章改版,新人大佬都可)

    [JavaScript实用技巧(二)]Js操作DOM(由问题引发的文章改版,新人大佬都可!) 博客说明 文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人 ...

  3. JavaScript基础15——js的DOM对象

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

  4. 原生js操作DOM基础-笔记

    原文参考http://mp.weixin.qq.com/s?__biz=MzU3MDA0NTMzMA==&mid=2247485490&idx=1&sn=15197b4b53e ...

  5. js的DOM对象

    1.js的Array对象           ** 创建数组(三种)                          - var arr1 = [1,2,3];                    ...

  6. 前端之JavaScript:JS之DOM对象三

    js之DOM对象三   一.JS中for循环遍历测试 for循环遍历有两种 第一种:是有条件的那种,例如    for(var i = 0;i<ele.length;i++){} 第二种:for ...

  7. 前端之JavaScript:JS之DOM对象二

    继续JS之DOM对象二 前面在JS之DOM中我们知道了属性操作,下面我们来了解一下节点操作.很重要!! 一.节点操作 创建节点:var ele_a = document.createElement(' ...

  8. 前端之JavaScript:JS之DOM对象一

    js之DOM对象一 一.什么是HTML  DOM HTML  Document Object Model(文档对象模型) HTML DOM 定义了访问和操作HTML文档的标准方法 HTML DOM 把 ...

  9. 框架操作DOM和原生js操作DOM比较

    问题引出 对于Angular和React操作DOM的速度,和原生js操作DOM的速度进行了一个比较: 一个同学做的demo 代码如下: <!DOCTYPE html> <html n ...

随机推荐

  1. eclipse关联源码的方法

    1.在项目的libs目录下,新建一个android-support-v4.jar.properties文件 2.打开android-support-v4.jar.properties,编辑. 输入源码 ...

  2. jquery datatable 参数api

    jQuery 的插件 dataTables 是一个优秀的表格插件,提供了针对表格的排序.浏览器分页.服务器分页.筛选.格式化等功能.dataTables 的网站上也提供了大量的演示和详细的文档进行说明 ...

  3. vb6 控件未注册问题解决

    打开项目时弹出如题错误. 另附一个帖子:http://bbs.csdn.net/topics/390580540,这个帖子讨论的不错,可以提供很多思路. 解决办法:http://rewwensoftw ...

  4. 很好的容斥思想 HDU 5514

    题目描述:有n只青蛙,m个石头(围成圆圈).第i只青蛙每次只能条a[i]个石头,问最后所有青蛙跳过的石头的下标总和是多少? 思路:经过绘图我们发现,每次跳过的位置一定是k*gcd(a[i], m).然 ...

  5. SQL 合并列值和拆分列值

    合并列值 表结构,数据如下: id value ----- ------ aa bb aaa bbb ccc 需要得到结果: id values ------ ----------- aa,bb aa ...

  6. Clock Pictures

    Clock Pictures 题目描述 You have two pictures of an unusual kind of clock. The clock has n hands, each h ...

  7. OpenGL与vs编程——error C2440: “glMaterialfv”: 无法从“GLfloat”转换为“const GLfloat *”

    void setMaterial(const GLfloat mat_diffuse[4],GLfloat mat_shininess){static const GLfloat mat_specul ...

  8. MySQL 常用基础命令

    一.启动与关闭 1.1 Linux下启动mysql 的命令: a. rpm包安装:service mysqld start b. 源码包安装:/usr/local/mysql/bin/mysqld_s ...

  9. Java中常见的5种WEB服务器介绍

    这篇文章主要介绍了Java中常见的5种WEB服务器介绍,它们分别是Tomcat.Resin.JBoss.WebSphere.WebLogic,需要的朋友可以参考下 Web服务器是运行及发布Web应用的 ...

  10. HDU 1269 迷宫城堡 tarjan算法求强连通分量

    基础模板题,应用tarjan算法求有向图的强连通分量,tarjan在此处的实现方法为:使用栈储存已经访问过的点,当访问的点离开dfs的时候,判断这个点的low值是否等于它的出生日期dfn值,如果相等, ...