什么是DOM

1:文档对象模型(DocumentObjectModel,DOM)

2:DOM定义了访问和操作HTML文档的标准方法。

3:DOM将HTML 文档表达为树结构。

其他查询元素的方法:

  document.querySelector(" ")  //获取元素

                 .表达根据类查找

                 #表示根据id查找

                 直接写表示根据标签名查找

                 [name = 值]表示根据某一个属性查找

document.querySelectorAll(" ")        // 获取元素集合(就算页面上只有一个元素,取出的也是集合)

eval(" ")   // 通过id名称获取元素

直接通过id名获取元素(部分IE不支持)

修改元素:

  元素(节点)是不能直接修改的,可以先删除,再创建。

对某元素的各种属性修改,比如:

  div1.innerHTML= "新的内容"; //演示innerText和outerHTML

  input1.value = "新的内容";

  input.type = "button";  //将input1元素的类型改为按钮

  span1.style.color = "red";

document.createElement(elementName);

指再文档下创建某个标签,elementName指标签名,如div,ul,li,img,a等等

element1.appendChild(element2);

指将element2元素,放入element1元素的内容,以追加的形式存放。

删除某元素:

ul1、removeChild(li3);  // 在ul1元素内,移除li3元素

注意:

  1:只在子节点下删除,想删除哪个节点,必须找到该节点的父节点,parentNode即父节点。

  2:只能删除1个节点,不能直接删除集合。

  3:如果用变量保存一个集合,对集合内的某个元素进行修改后,

    该变量存储的元素会发生变化。比如:

    var arr=document.getElementsByTagName("div");

    document.body.removeChid(arr[0]); //代码执行完,arr里面所有的元素都会向前进一位

  // 即原来的arr[1]由arr[0]表示。

DOM :自定义属性: 元素上有些是系统默认就含有的属性,比如id、title、name、style等。

  自定义的属性: 有些是根据自己喜好定义出来的属性,比如abc、xxx等。

          自定义属性通常来做数据存储。(可理解成变量赋值)。

  html:

    <div id= "div1" a="123" data-b="hello"></div>

  解释:在上文代码中,id是div的自带属性,a和b都是自定义属性,其中a是旧的写法,b是新的写法。

html:

  <div id="div1" a= "123" data-b = "hello"></div>

操作属性的方法有很多种,不同的方法对应的是不同类型的属性。

最常用的写法:

  div.c = "你好";  //设置属性

  console.log(div.c); //获取属性

注:使用这种方法获取自定义属性时,必须使用js的方法设置属性,使用html的方法设置是无法获取的。

html:

  <div id = "div1" a = "123" data-b = "hello"> </div>

另一种比较常用的写法:

  div1.setAttribute("d","你好");   //设置属性

  console.log(div1.getAttribute("d")); //获取属性

注: 使用这种方法设置的自定义属性,其内容会自动转为字符串。

html:

 <div id= "div1" a="123" data-b = "hello" ></div>

 自定义属性中的新的写法:

  div1.dataset.a = "你好"; //设置属性

  console.log(div1.dataset.e); //获取属性

注:有些浏览器不支持。

html:

  <div id="div1" a= "123" data-b = "hello"></div>

 存在,但不推荐的写法:

  div1.attribute.f = "你好"; /设置属性

  console.log(div1.attributes.f); //获取属性

不推荐使用,了解即可,因为使用比较复杂。

1,如果直接在html中写行间属性,通过该方法获取时返回属性节点。

2,如果即在行间设置了属性,也通过了js设置了属性,获取时返回属性节点。

3,如果没在行间设置属性,仅在js设置了属性,获取时返回数据。

如果是系统默认就含有的属性,通过不同方法设置的属性,可以通过不用的方法获取。

如果是根据自己喜好定义出来的属性,不用的方法设置的,是不能通过不同方法获取的。

例如: 用setAttribute设置后,可以用attributes获取,但用attributes设置,不能用getAttribute获取;

在实际开发中,以.这种方法为主,除非有要求说要在html中保存属性,否则我们不采用其他方法。

真实开发中,如果html中已经存在了自定义属性,需要我们通过js拿到自定义属性,看这个属性是怎么定义的,如果没有data前缀,则用getAttribute,否则用dataset。

div1.aa = [1,2,3];

console.log(div1,aa); //[1,2,3];

div1.setAttribute("aa",[1,2,3]);

console.log(div1.getAttribute("aa")); // "1,2,3"

区别 :

  1: 用 .aa 方法设置后,如果设置一个数组,能够取出数组,而setAttribute设置的是.toSring() 后的结果。

  2:用 .aa方法设置后,html上看不到,而setAttribute是能够看到的。

DOM的基本操作的更多相关文章

  1. JS基础---Dom的基本操作

    DOM的增删改查 增: 1.创建一个元素节点 document.createElement() 创建新的<p> 元素:var para=document.createElement(&qu ...

  2. JavsScript中DOM的基本操作

    节点及其类型 元素节点 属性节点: 元素的属性, 可以直接通过属性的方式来操作. 文本节点: 是元素节点的子节点, 其内容为文本. 在 html 文档的什么位置编写 js 代码 直接在 html 页面 ...

  3. JQuery Dom的基本操作

     这是赋值 $("#test").val ("aaa"); 这是取值 string s = $("#test").val (); text( ...

  4. js学习总结:DOM节点二(dom基本操作)

    一.DOM继承树 DOM——Document Object Model DOM定义了表示修改文档所需要的方法.DOM对象即为宿主对象,由浏览器厂商定义,用来操作html和xml的一类厂商定义,也有人称 ...

  5. Js杂谈-DOM

    前言 对jQuery的依赖.导致js的原生方法的淡忘,如果是封装自己的库,那势必要用到js的许多原生方法.从Jquery强大的dom处理开始,我们开始回顾javascript那些古老而坚挺的DOM方法 ...

  6. javascript DOM操作HTML文档

    文档对象模型(DOM)是W3C为解决浏览器混战时代不同浏览器环境之间的差别而制定的模型标准.W3C将文档对象模型定义为:是一个能让程序和脚本动态 访问和更新文档内容.结构和样式的语言平台.提供了标准的 ...

  7. JavaScript基础学习(九)—DOM

    一.DOM概述      DOM(Document Object Model)文本对象模型.      D: 文档,HTML文档或XML文档.      O: 对象,document对象的属性和方法. ...

  8. BOM及DOM及事件

    知识内容: 1.BOM介绍 2.DOM操作 3.事件 参考:http://www.cnblogs.com/liwenzhou/p/8011504.html 入门代码(DOM基本操作与事件): < ...

  9. 一篇文章搞懂DOM

    学习JavaScript肯定是会遇到DOM操作,那么什么是DOM?它又是干嘛用的?这篇文章为你揭晓答案. DOM是document object model的缩写,简称文档对象模型. 简单的说DOM是 ...

随机推荐

  1. solidity return data和revert/require的reason string的获得

    前言: 在使用solidity写智能合约的时候,会使用到revert和require来进行断言,比如: require(tokenOwner[tokenId] == 0x0,'this is not ...

  2. shell编程之循环

    一.for循环 for循环是Shelll中最常见的循环结构,根据书写习惯又分为列表for循环.不带列表的for循环以及类C的for循环.for循环是一种运行前的测试语句,也就是在运行任何循环体之前先要 ...

  3. P1-Linux下安装MySQL及登录用户配置

    Linux下安装MySQL及登录用户配置 环境:Centos7.4    Mysql5.6 1. 查询是否安装 MySQL和MariaDB rpm -qa | grep -i mysql rpm -q ...

  4. MTALAB——神经网络mae()、mse()、sse()

    mae():平均绝对误差 mse:均方误差 sse:误差平方和

  5. ESP32 I2S

    I2S支持DMA; I2S可以直接利用DAC来输出模拟信号 (GPIO 25 & GPIO 26): 高精度时钟使能参数:   .use_apll = true ESP32配置外设一般都是配置 ...

  6. 【Luogu P1074】靶形数独

    Luogu P1074 题意:给一个数独,问怎么填会使每个位置填的数乘以它的权值得到的和最大.其中每个位置的权值在题面中给出了. 思路:首先我们考虑搜索.由于我们不可能搜每个格子取太多的数,所以我们从 ...

  7. 九,ESP8266 判断是断电上电(强制硬件复位)之后运行的内部程序还是内部软件复位之后运行的程序(基于Lua脚本语言)

    现在我有一个需求,WIFI模块控制一个继电器,我要做的是如果内部程序跑乱了,造成了内部程序复位重启,那么控制继电器的状态不能改变 如果是设备断电了,然后又来电了,我需要的是继电器一定要是断开才好.不能 ...

  8. 在Oracle中执行动态SQL的几种方法

    转载:在Oracle中执行动态SQL的几种方法 以下为内容留存: 在Oracle中执行动态SQL的几种方法 在一般的sql操作中,sql语句基本上都是固定的,如:SELECT t.empno,t.en ...

  9. python游戏开发之俄罗斯方块(一):简版

    编程语言:python(3.6.4) 主要应用的模块:pygame (下面有源码,但是拒绝分享完整的源码,下面的代码整合起来就是完整的源码) 首先列出我的核心思路: 1,图像由"核心变量&q ...

  10. Codechef STREDUC Reduce string Trie、bitset、区间DP

    VJ传送门 简化题意:给出一个长度为\(l\)的模板串\(s\)与若干匹配串\(p_i\),每一次你可以选择\(s\)中的一个出现在集合\(\{p_i\}\)中的子串将其消去,其左右分成的两个串拼接在 ...