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修改样式的更多相关文章

  1. JavaScript基础:DOM操作详解

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. 前言 JavaScript的组成 JavaScript基础分为三个部分: ...

  2. javascript基础:dom

    Dom: * 概念:Document Object  Model    文档对象模型 * 将标记语言文档的各个组成部分,封装成对象,可以使用这些对象,对标记语言文档进行CRUD的动态操作 *    D ...

  3. JavaScript基础08——DOM

    DOM的概念 DOM是document Object Model的缩写,简称文档对象模型.他给文档提供了一种结构化的表示方式,可以改变文档的内容和呈现方式 所谓的DOM是以家族的形式描述HTML.父子 ...

  4. JavaScript基础 -- 常见DOM树操作

    1.创建并增加元素节点 <ul id="ul"> <li>1</li> <li>2</li> <li>3&l ...

  5. JavaScript 基础知识 - BOM篇

    前言 本篇文章是JavaScript基础知识的BOM篇,如果前面的<JavaScript基础知识-DOM篇>看完了,现在就可以学习BOM了. 注意: 所有的案例都在这里链接: 提取密码密码 ...

  6. javascript基础系列(入门前须知)

    -----------------------小历史---------------------------- javascript与java是两种语言,他们的创作公司不同,JavaScript当时是借 ...

  7. JavaScript DOM高级程序设计 5动态修改样式和层叠样式表2--我要坚持到底!

    把样式置于DOM脚本之外 style属性 我们可以这样设置前景色之类的属性: element.style.color='red'; 也可以使用下面的代码设置背景颜色: element.style.ba ...

  8. 第一百一十六节,JavaScript,DOM操作样式

    JavaScript,DOM操作样式 一.操作样式 CSS作为(X)HTML的辅助,可以增强页面的显示效果.但不是每个浏览器都能支持最新的CSS能力.CSS的能力和DOM级别密切相关,所以我们有必要检 ...

  9. JavaScript基础(2)-DOM

    一.伪数组arguments arguments代表的是实参,有个讲究的地方是:arguments只在函数中使用. 1.返回函数实参的个数:arguments.length,例如: fn(2,4); ...

随机推荐

  1. Android Paint的属性

    在Paint中有很多的属性可以设置,比如可以设置阴影,颜色过滤等等,这些会产生不同的奇妙效果,今天就对各种属性探索一下. 方法一: 1 //设置绘制的颜色,a代表透明度,r,g,b代表颜色值. 2 s ...

  2. Ubuntu 16.04 安装mysql并设置远程访问

    说明: 一个朋友在使用ubuntu-server 16.04安装mysql,设置远程访问的时候出现了问题,请我帮忙.但是,我也没有使用过ubuntu安装mysql,于是乎搜索了很多技术文件,比着葫芦画 ...

  3. javascript 组合

    1. 大数组中有m个元素,抽取其中的n个进行组合. var combination = function(arr, num){ var r=[]; (function f(t,a,n) { ) { r ...

  4. 复旦大学2015--2016学年第二学期(15级)高等代数II期末考试第六大题解答

    六.(本题10分)  设 $n$ 阶复方阵 $A$ 的特征多项式为 $f(\lambda)$, 复系数多项式 $g(\lambda)$ 满足 $(f(g(\lambda)),g'(\lambda))= ...

  5. smarty模板引擎

    1.    使用smarty 1.1 项目引入 // 3, 连接数据库,提取相关数据 $title = "Smarty模板引擎"; $content = "Smarty模 ...

  6. Java-坦克大战

    利用Java语言中的集合.Swing.线程等知识点编写一个坦克大战游戏.(1) 画出敌我坦克的原理:在坦克类里面有一个布尔类型变量good.用于判断坦克的阵营,在创建坦克对象时在Tank类的构造方法中 ...

  7. Mac上配置Privoxy

    此文档适用于走Shadowsocks代理,想利用Privoxy将主机作为代理服务器的用户. 0.安装完Privoxy后,打开终端命令. 1.打开Privoxy的配置文件config: cd /usr/ ...

  8. python走起之第十三话

    前景介绍 到目前为止,很多公司对堡垒机依然不太感冒,其实是没有充分认识到堡垒机在IT管理中的重要作用的,很多人觉得,堡垒机就是跳板机,其实这个认识是不全面的,跳板功能只是堡垒机所具备的功能属性中的其中 ...

  9. 单例模式getInstance()

    /** * 对象的实例化方法,也是比较多的,最常用的方法是直接使用new,而这是最普通的,如果要考虑到其它的需要,如单实例模式,层次间调用等等. * 直接使用new就不可以实现好的设计好,这时候需要使 ...

  10. (转载)Linux如何编译安装源码包软件

    一.什么是源码包软件: 顾名思义,源码包就是源代码的可见的软件包,基于Linux和BSD系统的软件最常见:在国内源可见的软件几乎绝迹:大多开源软件都是国外出品:在国内较为出名的开源软件有fcitx;l ...