DOM---文档对象模型(Document Object Model)的基本使用
一、DOM简介
文档对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展置标语言的标准编程接口。它是一种与平台和语言无关的应用程序接口(API),它可以动态地访问程序和脚本,更新其内容、结构和www文档的风格(目前,HTML和XML文档是通过说明部分定义的)。
DOM 可被 JavaScript 用来读取、改变 HTML、XHTML 以及 XML 文档,它本身属于浏览器。
二、使用DOM查找HTML元素
HTML 文档中的所有节点组成了一个文档树(或节点树)。HTML 文档中的每个元素、属性、文本等都代表着树中的一个节点。树起始于文档节点,并由此继续伸出枝条,直到处于这棵树最低级别的所有文本节点为止。所以查找HTML中的某个标签即是查抄树上的某个节点。
1. 直接查找(通过属性、标签名等)
1 document.getElementById("i1"); //根据id获取单个元素 2 document.getElementsByName("i1"); //根据name属性获取多个元素 3 document.getElementsTagName('a'); //根据标签名称获取多个元素 4 document.getElementsByClassName('c1'); //根据class属性获取多个元素
2. 间接查找(通过已找到的其他标签)
1 tag = document.getElementById("i1"); 2 tag.parentElement // 父节点标签元素 3 tag.children // 所有子标签 4 tag.firstElementChild // 第一个子标签元素 5 tag.lastElementChild // 最后一个子标签元素 6 tag.nextElementSibling // 下一个兄弟标签元素 7 tag.previousElementSibling // 上一个兄弟标签元素
三、使用DOM操作标签
1. 操作标签内容
tag = document.getElementById("i1"); content = tag.innerText; //获取标签中的文本内容 tag.innerText = "new_content"; //将标签内部文本赋值为new_content
//使用innerText只能操作标签内部的文本内容,即使标签内部包裹了其他标签也会被其忽略 // 常用的操作标签内容的方法,使用方法同innerText innerText --- 仅文本 innerHTML --- 所有内容(包括标签) value: ---- 标签的值(下面分别是对有value属性的标签,使用value获取/操作值的详细介绍)input --- value获取当前输入的值select --- 获取选中value的值(selectedIndex)textarea --- 获取当前输入的
2. 操作标签一般属性
obj = document.getElementById("i1"); obj.attributes //---- 获取标签的所有属性 obj.getAttributes(key) //---- 获取标签某个属性的值 obj.setAttributes(key, value) //---- 为标签设置属性 obj.removeAttributes(key) //---- 为标签移除属性
3. 操作标签class属性
tag = document.getElementById('i1') tag.className // 获取tag的使用的class选择器名称 tag.className = 'c1' // tag使用名为c1的class选择器 tag.classList.add('c2') // 给tag增添c2中的样式 tag.classList.remove('c3') // 移除tag使用的c3中的样式
4. 操作标签样式
// 在上面的操作class属性中,是对一个标签添加或删除一个css代码样式块, 对一个标签具体样式的操作如下//比如,设置一个标签字体的大小 tag = document.getElementById("i1"); tag.style.fontSize = '16px';// 其他的各种样式也是采用这种方式设置,设置时样式字段去掉'-',将每个单词的首字母大写(整体首字母小写,tag.style.backgroundColor)
5. 创建标签和操作标签
// 创建标签方式一: var tag = "<a class='c1' href='http//:www.cnblogs.com'>博客园</a>"// 创建标签方式二: var tag = document.createElement('a') tag.innerText = "博客园" tag.className = "c1" tag.href = "http://www.cnblogs.com"
// 操作标签,即将创建的插入整个HTML文档的某个位置// 方式一 var mytag = document.getElementById('i1') var obj = "<input type='text' />"; mytag.insertAdjacentHTML("beforeEnd",obj); //将标签插入到mytab所代表的标签结束之前的位置,即最后一个子标签 mytag.insertAdjacentElement('afterBegin',document.createElement('p')); //将标签插入到mytab所代表的标签开始之后的位置,即第一个子标签 //注意:第一个参数只能是'beforeBegin'、 'afterBegin'、 'beforeEnd'、 'afterEnd'// 方式二 var tag = document.createElement('a') xxx.appendChild(tag) // 将新标签作为xxx的最后一个标签 xxx.insertBefore(tag,xxx[1]) // 将新标签插入xxx的第一个子标签之前
相关文章:

剑指offer--3题
题目:输入一个整形数组,数组里有正数也有负数。数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。求所有子数组的和的最大值。要求时间复杂度为O(n)。 例如输入的数组为1, -2, 3, 10, -4, 7, 2, -5,和最大的子数组…

php可以打印一个页面,利用html实现分页打印功能的实例详解
本篇介绍利用html实现分页打印功能的实例详解,有些不想打印出来的分页打印的都可以应用这类样式进行控制 在非打印时是无效的。页面打印/* 应用这个样式的在打印时隐藏 */.noPrint {display: none;}/* 应用这个样式的,从那个标签结束开始另算一页&#x…

java动态加载配置文件
最近项目中需要做定时任务,即定时数据库的备份。定时时间用户可以在界面中配置,要求配置修改好立即生效。 想不到什么好办法。下面是一种实现思路 把用户配置的时间存到properties配置文件中,定时任务每隔一分钟执行一次,每次执行…

商品秒杀,防并发解决思路
我们在做电商项目的时候,经常会遇到抢购秒杀的问题,综合来说主要是两个问题 一,高并发情况下对数据库产生的压力 二,如何避免超卖(库存< 0)的情况。 针对这两个问题来谈下解决思路 一,缓解数据库压力 用 缓存就可以解决 例如redis,memecac…

【组队学习】【31期】动手学数据分析
动手学数据分析 航路开辟者:陈安东、金娟娟、杨佳达、老表、李玲、张文涛、高立业领航员:陈玉立航海士:陈安东、武帅、肖涵哲、叶前坤、沈豪 基本信息 开源内容:https://github.com/datawhalechina/hands-on-data-analysis内容…

php不报错怎么回事,解决PHP 7等web编程语言不报错一例
PHP的开发者必须尽快转到PHP 7平台,因为原来在PHP 5下开发的程序,有很多在PHP 7下都会报错。PHP 5的程序改为PHP 7的写法,工作量是很大的,所以开发者只能一步到位转到PHP 7平台。PHP 7增强了数据类型;数组与变量名不能…

在存储过程中如何实现将ID列表字符串传入IN()
我们在平常编写sql语句时,经常碰到要把id列表字符串(比如:001,002,003,....)当做参数传递给存储过程, 那么在存储过程中要用in作为条件进行记录的过滤,那么采用in(idList)࿰…

【组队学习】【31期】数据可视化(Matplotlib)
数据可视化(Matplotlib) 航路开辟者:杨剑砺、杨煜、耿远昊、李运佳、居凤霞领航员:贾献华航海士:杨剑砺、郭棉昇、张文恺、肖桐 基本信息 开源内容:https://github.com/datawhalechina/fantastic-matplo…

java学习路线图(2018年最新版)
最近有些网友问我如何自学 Java 后端,还有些是想从别的方向想转过来,但都不太了解 Java 后端究竟需要学什么,究竟要从哪里学起,哪些是主流的 Java 后端技术等等,导致想学,但又很迷茫,不知从何下…

php instr函数,oracle的instr函数用法
这几天在做一个项目的时候,做到关于用户组权限分配的问题,用到了Oracle的instr函数,现在好好学习下这个函数吧。 在Oracle/PLSQL中, instr 函数返回要截取的字符串在源字符串中的位置。 语法如下:instr( string1, stri…

浏览器内核Trident/Gecko/WebKit/Presto
“浏览器内核”主要指渲染引擎(Rendering Engine),负责解析网页语法(如HTML、JavaScript)并渲染、展示网页。因此,所谓的浏览器内核通常也就是指浏览器所采用的渲染引擎, 渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息。不同的浏…
Intellij IDEA 将工程转换成maven工程 详解
1> 右键工程,点击 Add Framework Support2> 选中 Maven,再点击 OK3> 工程根目录自动生成 pom.xml 文件,这样 工程就支持 Maven版权声明:本文为博主原创文章,未经博主允许不得转载。 http://blog.csdn.net/che…

【组队学习】【31期】水很深的深度学习
水很深的深度学习 航路开辟者:刘洋领航员:陈宇航海士:刘洋、陈陟原、左凯文、初晓宇、刘羽中 基本信息 开源内容:https://github.com/datawhalechina/unusual-deep-learning内容属性:公测课程内容说明:本…

php返回结果判断,老司机在判断返回结果时翻了个身(ThinkPHP)
“这篇文章属于基本内容。看到它的学生检查他们的代码是否有同样的问题“序言小q又带着问题来了,今天的问题估计是大多数同志都会犯的问题。问题是使用ThinkPHP时查询返回的结果是否为空。你自信吗?你不知道的是空的!如果你是这样认为的&…

ZooKeeper客户端地址列表的随机原理
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nileader.blog.51cto.com/1381108/932948查看PDF版本 转载请用注明:ni掌柜nileadergmail.com 在之前一个文章《ZooKeeper Jav…

Intellij IDEA使用教程(超详细)
转自 http://www.phperz.com/article/15/0923/159067.html转载于:https://www.cnblogs.com/lijingran/p/8585430.html

【组队学习】【31期】青少年编程(Scratch 四级)
青少年编程(Scratch 四级) 航路开辟者:王思齐、马燕鹏领航员:马燕鹏航海士:王思齐、马燕鹏 基本信息 开源内容:https://github.com/datawhalechina/team-learning-program/tree/master/Scratch内容属性&…

java中mypoiexception,java - 如何使用Poi获取Java中单元格的数据验证源? - 堆栈内存溢出...
此问题包含多个不同的问题。首先,我们需要获取工作表的数据验证,然后为每个数据验证获取数据验证所适用的Excel单元格范围。 如果该单元格位于该单元格范围之一中,并且数据验证是列表约束,则进行进一步处理。 否则返回默认值。如果…

[20180317]12c TABLE ACCESS BY INDEX ROWID BATCHED2.txt
[20180317]12c TABLE ACCESS BY INDEX ROWID BATCHED2.txt--//简单探究12c TABLE ACCESS BY INDEX ROWID BATCHED特性.--//当使用12c时,执行计划出现TABLE ACCESS BY INDEX ROWID BATCHED,做一些探究.--//本文主要探究如何使用提示或者隐含参数控制这种特性.1.环境:SCOTTtest01…

Angularjs集成第三方js插件之Uploadify
有时候需要用一些第三方插件,比如datepicker,slider,或者tree等。以前的做法是直接通过jquery取得某个元素,然后调用某个方法即可。但在angularjs中,不能直接这么写,必须写在directive中。 开源项目Angular…

备考12月份电子学会青少年编程能力等级测试(图形化)的公益训练营即将开营
一、考试安排 考试方式 考试形式:在线居家考试(全国)报名时间:9月26日08:00 ~ 11月23日16:00退费截止时间:11月23日16:00准考证下载时间:11月30日 ~ 考前1天 考前集中测试时间 12月9日(周四…

mysql left join超时,MySQL 行锁超时排查方法优化
一、大纲#### 20191219 10:10:10,234 | com.alibaba.druid.filter.logging.Log4jFilter.statementLogError(Log4jFilter.java:152) | ERROR | {conn-10593, pstmt-38675}executeerror.updatexxxsetxxx ? , xxx ?whereRowGuid ?com.mysql.jdbc.exceptions.jdbc4.MySQLTra…

【优秀作业】蚁群优化算法
蚁群优化算法 一.概述 生物学家发现,自然界中的蚁群觅食是一种群体性行为,并非单只蚂蚁自行寻找食物源。蚂蚁在寻找食物源时,会在其经过的路径上释放一种信息素,并能够感知其它蚂蚁释放的信息素。信息素浓度的大小表…

RPC-原理及RPC实例分析
还有就是:RPC支持的BIO,NIO的理解 (1)BIO: Blocking IO;同步阻塞; (2)NIO:Non-Blocking IO, 同步非阻塞; 参考:IO多路复用,同步,异步,阻塞和非阻塞 区别 在学校期间大家都写过不少程序,比如写个…

hdu 4608 I-number
http://acm.hdu.edu.cn/showproblem.php?pid4608 直接暴力 代码: #include<iostream> #include<cstdio> #include<string> #include<cstring> #include<cmath> #include<set> #include<map> #include<stack> #inc…

php tab标签,JavaScript代码分享:tab标签的切换
本文实例讲述了js实现点击切换TAB标签。分享给大家供大家参考。具体如下:这里演示的选项卡效果代码,无jq,纯JS来实现,灰色风格,没有怎么美化,或许看上去比较普通,不过兼容性和操作起来挺舒服的,…

二进制,十进制,十六进制
生活中其实很多地方的计数方法都多少有点不同进制的影子。 比如我们最常用的10进制,其实起源于人有10个指头。如果我们的祖先始终没有摆脱手脚不分的境况,我想我们现在一定是在使用20进制。 至于二进制……没有袜子称为0只袜子,有一只袜子称为…

D3.js系列——初步使用、选择元素与绑定数据
D3 的全称是(Data-Driven Documents),顾名思义可以知道是一个被数据驱动的文档。听名字有点抽象,说简单一点,其实就是一个 JavaScript 的函数库,使用它主要是用来做数据可视化的。 D3 提供了各种简单易用的…

秦州:西瓜书 + 南瓜书 吃瓜系列 12. 聚类
Datawhale南瓜书是经典机器学习教材《机器学习》(西瓜书)的公式推导解析指南,旨在让在学习西瓜书的过程中,再也没有难推的公式,学好机器学习。 航路开辟者:谢文睿、秦州开源内容:https://githu…

php 5/0,PHP 5.5.0 released.该怎么解决
当前位置:我的异常网 PHP PHP 5.5.0 released.该怎么解决PHP 5.5.0 released.该怎么解决www.myexceptions.net 网友分享于:2013-08-02 浏览:12次PHP 5.5.0 released.The PHP development team is proud to announce the immediate availability of PH…