1.HTML DOM是什么,以及它的作用:

  w3c对DOM有一系列的解释和定义,用自己理解的话来说就是:HTML DOM是html的标准对象模型,可以使JavaScript去操作(获取,修改,删除,添加,)HTML对象。

2.DOM 如何获取HTML元素?

  在DOM中访问HTML元素的方法有多种 :

  1.DOM 节点:

    (在核心DOM中访问父子,兄弟节点)

    node.parentNode    访问父节点

    node.childNodes          访问所有子节点

    node.firstChild    访问第一个子节点

    node.lastChild    访问最后一个子节点

    node.nextSibling   访问下一个兄弟节点

    node.previousSibling 访问上一个兄弟节点

    (由核心DOM精简出的HTML DOM访问父子、兄弟节点)

    element.parentElement      访问父元素

    element.childern         访问所有子元素

    element.firstElementChild     访问第一个子元素

    element.lastElementChild     访问最后一个子元素

    element.nextElementChild       访问下一个子元素

    element.perviousElementChild    访问上一个子元素

  这两者之间的区别就在于 核心DOM无论访问的是父子节点还是兄弟节点 都会将空格,换行符当做节点 这就会造成使用的不便,而精简的HTML DOM 只会访问HTML中的元素。

  2.DOM 方法

    getElementById(id属性值)        返回带有id的元素

    getElementsByTagName(标签名)       返回指定标签名的所有元素 以数组的形式存储

    getElementsByClassName(class属性值)  返回是定类名的所有元素 以数组形式存储

    getElementsByName(name属性值)

  3.css选择器

    document.querySelectorAll(" ")  通过选择器获取元素  返回一个数组

    document.querySelector(" ")   通过选择器获取元素  返回一个元素

3.DOM 如何修改HTML元素的内容、属性、样式

  1.修改其内容(element表示某个元素)

    对于双标签:element.innerHTML = “……”

          element.text/textcontent = " …… "

    这两者的差别在于 innerHTML 修改的是包含标签的文本内容 而text、textcontent修改的是纯文本内容

    对于单标签:element.value = " ……"

  2.修改其属性

    element.class = " " 修改class属性

    element.href  =  " " 修改超链接href属性

    当赋值为空时相当于移除这个元素的属性

  3.修改其样式

    element.style.fontSize = "16px"  修改字体大小

    获取标签的样式:getcomputedstyle("标签名") 通过这种方式获取到的样式 只可以查看 不可以修改

4.DOM 如何添加HTML元素

  1.追加

    element.appendChild(elem)   向父元素element追加一个子元素elem

  2.插入

    element.insertBefore(elem,oldElem)  向父元素的oldElem元素前插入一个elem元素

  3.替换

    element.replaceChild(elem,oldElem)  将父元素element的oldElem替换为elem元素

  向DOM树添加新元素的方法有多种,使用方法视情况而定,这里举例一种最常用的方法:

1.创建一个新的元素 var div = document.createElement("div")

2.设置其内容:div.innerHTML = "  " (若是不需要添加内容可以省略)

3.追加到父元素或者HTML中:parent.appendChild(div)

需要注意的是 由于每向DOM中添加一次元素都会重新对每个元素进行计算和定位 非常耗时 所以尽量将需要添加的元素结构先在内存中构造好 再整体一次性添加到DOM树中

5.DOM如何删除HTML元素

  parentNode.removeChild(elem)  删除父节点的elem子节点

  

  

  

Javascript--HTML DOM基础知识的更多相关文章

  1. javascript中DOM基础知识介绍

    1.1.     基本概念 1.1.1.      DOM DOM Document Object Model 文档对象模型 就是把HTML文档模型化,当作对象来处理 DOM提供的一系列属性和方法可以 ...

  2. HTML DOM基础知识

    HTML DOM基础知识 一.什么是DOM? 1.HTML DOM 定义了访问和操作HTML文档的标准方法. 2.HTML DOM 把 HTML 文档呈现为带有元素.属性和文本的树结构(节点树). 3 ...

  3. javascript之正则表达式基础知识小结

    javascript之正则表达式基础知识小结,对于学习正则表达式的朋友是个不错的基础入门资料.   元字符 ^ $ . * + ? = ! : | \ / ( ) [ ] { } 在使用这些符号时需要 ...

  4. ArcGIS API for JavaScript开发初探——基础知识

    1.前言 在ArcGIS Web API开发体系中一共有四大类,分别为: ArcGIS API for Flex ArcGIS API for JavaScript ArcGIS API for RE ...

  5. HTML DOM 基础知识,成为javascript晋级高手的必备手册

    一.DOM 简介,什么是 DOM? 文件对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展置标语言的标准编程接口. 标记语言,也称置标语言,是一种将文本( ...

  6. javascript——对象的基础知识

    一.javascript作为脚本语言可以完成以下任务: 操纵浏览器对象,如窗口的打开与关闭: 操纵Dom树: 通过XMLHttpRequest对象与服务器端进行异步通信: XML编程,借助于Activ ...

  7. DOM基础知识整理

    --<JavaScript高级程序设计>Chapter10学习笔记 一.节点层次 1.Node类型 1)(Node).nodeType属性 节点nodeType属性有12种. 检测node ...

  8. JavaScript进阶【三】JavaScript面向对象的基础知识复习

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

  9. JavaScript之DOM基础

    概述 DOM(Document Object Model)文档对象模型,针对Html和XML的文档的对象API,是一项 W3C (World Wide Web Consortium) 标准.文档对象模 ...

随机推荐

  1. API的查看

    步骤: 1. 双击打开API 2. 点击显示, 找到索引 3. 输入要查找的类名 , 敲击Enter两次 4. 看该类所属的包, java.lang包下的类,在使用的时候不需要导包 ,其他的都需要导包 ...

  2. 关于define('DISCUZ_ROOT', substr(dirname(__FILE__), 0, -7));的理解

    关于define('DISCUZ_ROOT', substr(dirname(__FILE__), 0, -7));的理解 define('DISCUZ_ROOT',  substr(dirname( ...

  3. Kubernetes简介二

    Kubernetes是什么?Kubernetes是容器集群管理系统,是一个开源的平台,可以实现容器集群的自动化部署.自动扩缩容.维护等功能.通过Kubernetes你可以: 快速部署应用 快速扩展应用 ...

  4. 配置Apache控制浏览器端的缓存的有效期

    这个非常有用的优化,mod_expires可以减少20-30%左右的重复请求,让重复的用户对指定的页面请求结果都CACHE在本地,根本不向服务器发出请求.但要注意更新快的文件不要这么做.这个模块控制服 ...

  5. robot:生成随机的8为纯数字

    1.引进random库 2.注意最后面的random为需要引入的包

  6. 生成count位随机数工具类

    工具类 import java.util.Random; /** * 生成6位随机数字 */ public class GeneratorCode { /** * * @Title: getCode ...

  7. Python的发展历史及其前景

    Python的发展历史 1989年,吉姆·范罗苏姆为打发时间,决定为当时正构思的一个新的脚本语言编写一个解释器.作为派森的狂热粉丝,他以Python命名该项目,使用C进行开发. 1991年发布Pyth ...

  8. tp5博客项目实战1

    tp5博客项目实战 开发准备:环境wamp,windows系统为例.看实战博客,默认会搭建开发环境并且tp5框架已经至少有一定的基础. tp5的下载与安装 方法一:直接在官网下载拷贝到wamp你的项目 ...

  9. VMware虚拟机中CentOS7的硬盘空间扩容

    查看centos7系统挂载点信息 扩展VMWare-centos7硬盘空间 对新增加的硬盘进行分区.格式化 添加新LVM到已有的LVM组,实现扩容 1.查看centos7系统挂载点信息 df -h查看 ...

  10. 2019年11月27日 Linux所学知识 总结

    查看网络信息和网络状态 nmcli connection show 使用con-name参数指定公司使用的网络会话名称company,然后依次用ifname参数指定本机的网卡名称. 用autoconn ...