JavaScript基础之DOM修改样式
1.获取或设置元素的内容:3个属性:
1. innerHTML: 获取或设置元素开始标签到结束标签之间的所有HTML代码原文。
何时使用:只要获得完整的html代码原文时
优化:如果批量删除或插入多个子元素时,尽量避免单个操作!
每次插入或删除操作都会导致排版引擎重新layout。
如果批量删除或插入,排版引擎只需要一次layout即可。
如何优化:
1. 删除: parent.innerHTML="";
2. 插入: parent.innerHTML="多个元素的html标签组成的html代码字符串";
2. textContent: 仅获取或设置元素开始标签到结束标签之间的文本内容。不包含标签。如果是特殊符号,会返回特殊符号的正文。
IE8不兼容: innerText
2. ***获取或设置元素的属性:
凡是元素的属性都是字符串!
1. 获取元素的属性:3种:
1. var attrNode=elem.attributes[i/"属性名"]
获得属性节点对象
attrNode.value 获得属性中的值
*2. elem.getAttribute("属性名") 直接返回属性值!
3. elem.getAttributeNode("属性名") 获得属性节点对象
.value才能获得值
2. 设置元素的属性: 3种:——核心DOM
1. elem.attributes[i/"属性名"].value="属性值"
只能修改现有属性
*2. elem.setAttribute("属性名","属性值")
即可新增属性,也可修改现有属性
3. elem.setAttributeNode(属性节点对象)
Elem1.setAttributeNode(elem2.attributes["属性名"])
3. 判断元素中是否包含指定属性:
elem.hasAttribute("属性名")-->包含:true,否则:false
4. 删除元素中的指定属性:
elem.removeAttribute("属性名")
总结:attributes get/set/has/removeAttribute
***属性(Property) vs 特性(Attribute)
属性: 内存中一个对象的成员属性,一般用.访问
特性: 页面中html元素上的html属性,一般用get/setAttribute
对于html标准属性:二者完全相同!
HTML DOM将所有标准属性已经封装在了元素对象中
如果没有主动设置,默认值为""
elem.属性名="值"
自定义特性:只能用核心DOM访问 ——只能访问页面元素中的
html5:elem.dataset保存了所有页面元素中的自定义特性
设置/获取:elem.dataset.属性名
专门访问以data-开头的自定义特性
手动在页面添加自定义特性必须加data-前缀
***修改样式:2处:
1. 仅获取或设置内联样式:
elem.style.属性名="值";
其实elem.style是CSSStyleDeclaration类型的对象
封装了一个元素所有css样式属性的值
固定套路:清除一个元素的所有内联样式:
elem.style.cssText="";
2. 获取元素最终应用的所有样式:计算后的样式
var style=getComputedStyle(elem);
style也是CSSStyleDeclaration类型的对象
IE8:elem.currentStyle;
style.属性名
只要设置:elem.style.属性名 -> 加入内联样式,优先级最高!
不影响其他元素的样式
只要获取:var style=getComputedStyle(elem)
3. 改样式表中的样式:3步:chrome不支持本地的外部css文件
1. 从样式表集合中获取第i个样式表对象
var sheet=document.styleSheets[i]
sheet是CSSStyleSheet类型的对象:
1. sheet.cssRules集合: 样式表中所有cssRule对象
cssRule对象:css中每个{}就是一个cssRule对象
cssRule下还可包含子Rule,比如: @keyframes
2. cssRule对象下,又包含:
1. cssText: 保存Rule完整的字符串
2. selectorText: 选择器名称
*3. style: CSSStyleDeclaration
style.属性名
2. 获取CSSRule对象:
var rule=sheet.cssRules[i]
3. 通过rule获得style对象
var style=rule.style
style.属性名='值';
JavaScript基础之DOM修改样式的更多相关文章
- JavaScript基础:DOM操作详解
本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. 前言 JavaScript的组成 JavaScript基础分为三个部分: ...
- javascript基础:dom
Dom: * 概念:Document Object Model 文档对象模型 * 将标记语言文档的各个组成部分,封装成对象,可以使用这些对象,对标记语言文档进行CRUD的动态操作 * D ...
- JavaScript基础08——DOM
DOM的概念 DOM是document Object Model的缩写,简称文档对象模型.他给文档提供了一种结构化的表示方式,可以改变文档的内容和呈现方式 所谓的DOM是以家族的形式描述HTML.父子 ...
- JavaScript基础 -- 常见DOM树操作
1.创建并增加元素节点 <ul id="ul"> <li>1</li> <li>2</li> <li>3&l ...
- JavaScript 基础知识 - BOM篇
前言 本篇文章是JavaScript基础知识的BOM篇,如果前面的<JavaScript基础知识-DOM篇>看完了,现在就可以学习BOM了. 注意: 所有的案例都在这里链接: 提取密码密码 ...
- javascript基础系列(入门前须知)
-----------------------小历史---------------------------- javascript与java是两种语言,他们的创作公司不同,JavaScript当时是借 ...
- JavaScript DOM高级程序设计 5动态修改样式和层叠样式表2--我要坚持到底!
把样式置于DOM脚本之外 style属性 我们可以这样设置前景色之类的属性: element.style.color='red'; 也可以使用下面的代码设置背景颜色: element.style.ba ...
- 第一百一十六节,JavaScript,DOM操作样式
JavaScript,DOM操作样式 一.操作样式 CSS作为(X)HTML的辅助,可以增强页面的显示效果.但不是每个浏览器都能支持最新的CSS能力.CSS的能力和DOM级别密切相关,所以我们有必要检 ...
- JavaScript基础(2)-DOM
一.伪数组arguments arguments代表的是实参,有个讲究的地方是:arguments只在函数中使用. 1.返回函数实参的个数:arguments.length,例如: fn(2,4); ...
随机推荐
- 大数据 > 数据平台方案评估
分类 当前措施 说明 百度竞价如何进行数据分析(SEM工程师)数据来源: 1. 百度后台推广数据:api 总展现 总点击 点击率 总消费 点击均价 BDP功能点 1. 串联百度->网站商务通-& ...
- Oracle(创建视图)
概念: 视图:所谓视图就是提取一张或者多张表的数据生成一个映射,管理视图可以同样达到操作原表的效果,方便数据的管理以及安全操作. 视图其实就是一条查询sql语句,用于显示一个或多个表或其他视图中的相关 ...
- Linux服务器的那些性能参数指标
Linux服务器的那些性能参数指标 一个基于Linux操作系统的服务器运行的同时,也会表征出各种各样参数信息.通常来说运维人员.系统管理员会对这些数据会极为敏感,但是这些参数对于开发者来说也十分重要, ...
- 《简明python教程》笔记二
面向对象的编程: 类和对象是面向对象编程的两个主要方面.类创建一个新类型,而对象是这个类的实例.对象可以使用普通的属于对象的变量存储数据.属于一个对象或类的变量被称为域.对象也可以使用属于类的函数来具 ...
- ios framework 分离与合并多种CPU架构,分离与合并模拟器与真机
ios framework 分离与合并多种CPU架构,分离与合并模拟器与真机 如果你所用的framework支持真机和模拟器多种CPU架构,而你需要的是其中的一种或几种,那么可以可以从framewo ...
- JavaScript中的数组遍历forEach()与map()方法以及兼容写法
原理: 高级浏览器支持forEach方法 语法:forEach和map都支持2个参数:一个是回调函数(item,index,list)和上下文: forEach:用来遍历数组中的每一项:这个方法执行是 ...
- 易货beta版本测试报告
测试 对于服务器端我们是进行了单元测试 对于客户端我们使用的是在线的云测工具对app进行了包括安装,启动,具体功能以及ui方面的测试. 另外,对于客户端,我们还进行了对细节功能的人工测试 功能需求编号 ...
- 平衡二叉树AVL
1.定义 平衡二叉树(Balanced Binary Tree)是二叉查找树的一个改进,也是第一个引入平衡概念的二叉树.1962年,G.M. Adelson-Velsky 和 E.M. Landis发 ...
- (转)Linux NFS服务器的安装与配置
转自:http://www.cnblogs.com/mchina/archive/2013/01/03/2840040.html 由于在6系列里面,portmap已经改名了 ,6系列需要使用 serv ...
- 解决redhat 没注册的情况下yum无法使用的问题
官网下载的rhel,安装后是没有配置yum源的,需要自己配置yum源.网络上的很难找到rhel的yum源,但是在ISO镜像里面有很多redhat提供的软件包,也是正版软件,我们可以把这个拷贝出来 ...