DOM对象(文档对象模型)
HTML DOM 是 W3C 标准(是 HTML 文档对象模型的英文缩写,Document Object Model for HTML)。HTML DOM 定义了用于 HTML 的一系列标准的对象,以及访问和处理 HTML 文档的标准方法。通过 DOM,可以访问所有的 HTML 元素,连同它们所包含的文本和属性。可以对其中的内容进行修改和删除,同时也可以创建新的元素。

方法
2.1 document.getElementById("elementID");

定义和用法:
- 返回对拥有指定 ID 的第一个对象的引用
- 如果没有指定 ID 的元素返回 null

2.2 document.getElementsByTagName("tagname");

定义和用法:
- 返回带有指定标签名的对象的集合
- 参数值 "*" 返回文档的所有元素
- 返回的集合对象拥有 length 属性,并且可以通过 Index 来访问集合中的元素

2.3 document.getElementsByName("name");

定义和用法:
- 返回带有指定名称的对象的集合
- 返回的集合对象拥有 length 属性,并且可以通过 Index 来访问集合中的元素
- 存在兼容性问题(该方法适用于表单操作)
>IE 浏览器中,如果name存在于form表单中,可以正常使用,但是如果出现在例如div元素中,则不能正常返回值,原因是name并不是div的标准属性
>CHROM, FIREFOX 均正常

2.4 document.getElementsByClassName("classname");

定义和用法:
- 返回文档中所有指定类名的元素集合
- 返回的集合对象拥有 length 属性,并且可以通过 Index 来访问集合中的元素
- 存在兼容性问题(FF,CHROM 支持该方法,IE不支持)
解决办法:
```
function getElesByClassName(className) {
    var arr = [];
    if(document.getElementsByClassName) {
        return document.getElementsByClassName(className);
    } else {
        var tags = document.getElementsByTagName("*");
        for(var i = 0; i < tags.length; i++) {
            if(tags[i].className == className) {
                arr.push(tags[i]);
            }
        }
        return arr;
    }
}
3. 对象集合
3.1 all
所有对象的集合,常用来做兼容性判断
3.2 forms
所有form表单集合
console.log(document.forms.length);

通过 index 来访问表单对象
document.forms[0];

通过表单的 name 属性来访问表单对象
document.forms["name"];

4. 操作元素内容
4.1 innerHTML: 设置或获取标签对中的内容( 识别HTML )
4.2 innerText: 获取文字内容( IE ) textContent: 获取文字内容(FF,chrom)
function getContent(obj, val) {
    if(document.all) {
        if(val) {
            obj.innerText = val;
        } else {
            return obj.innerText;
        }
    } else {
        if(val) {
            obj.textContent = val;
        } else {
            return obj.textContent;
        }
    }
}
5. 属性操作
5.1 直接操作
object.attr = value ( 获取和设置 )
5.2 方法
获取: object.getAttribute("attr")
设置: 对象.setAttribute("attr", "value")
6. 样式操作
6.1 行内样式
设置和获取: object.style.attr 示例: hover
html:
<a id="one" href="#" style="color: red; padding: 3px;">跳转</a>
javascript:
(function() {
    var one = document.getElementById("one");
    one.onmouseover = function() {
        this.style.color = "blue";
        this.style.backgroundColor = "red";
    };
    one.onmouseout = function() {
        this.style.color = "red";
        this.style.backgroundColor = "blue";
    };
}());
6.2 css层叠样式
通过 className 修改样式
获取或修改某个属性的值(兼容性问题)
<table style='width:800px;font-size:14px;text-align:center;'><tr><th>属性</th><th>描述</th></tr><tr><td>document.styleSheets</td><td>返回样式表的集合</td></tr><tr><td>document.styleSheets[index].rules / document.styleSheets[index].cssRules</td><td>返回样式表中选择器的集合</td></tr><tr><td>document.styleSheets[index].rules[index].style.attr</td><td>查找样式表中的样式属性(**ie chrom**)</td></tr><tr><td>document.styleSheets[index].cssRules[index].style.attr</td><td>查找样式表中的样式属性(**firefox**)</td></table>
动态添加或删除
document.styleSheets[index].insertRule("selector{attr:value}", index);
document.styleSheets[index].deleteRule(index);
document.styleSheets[index].addRule("selector","attr:value", index);
document.styleSheets[index].removeRule(index);
6.3 获取最终样式(只能获取,不能操作)
object.currentStyle.attr ( IE )
window.getComputedStyle(object,null).attr ( W3C )
6.4 获得元素尺寸(可直接运算)
clientWidth/clientHeight: 元素可视部分的高度和宽度(width + padding)
offsetWidth/offsetHeight: 元素实际的高度和宽度(width+padding+border)

最新文章

  1. 适配各种Windows分辨率,为DPI添加感知,当在高DPI时,禁用WINFORM缩放等。
  2. android应用刷新系统多媒体库(增加or删除多媒体文件)
  3. slide效果
  4. 【BZOJ】1054: [HAOI2008]移动玩具(bfs+hash)
  5. Objective-C排序算法实现
  6. POJ1182
  7. 23 读取excel
  8. BIM与GIS
  9. SpringMVC项目读取不到外部CSS文件的解决办法及总结
  10. FormData对象的使用
  11. POJ - 1584 A Round Peg in a Ground Hole(判断凸多边形,点到线段距离,点在多边形内)
  12. 敏捷开发之Scrum扫盲篇(转)
  13. unity鼠标滚轮控制摄像机视野的缩放和按住鼠标控制摄像机移动
  14. &lt;容错性FaultTolerance&gt;&lt;Hadoop&gt;&lt;Spark&gt;
  15. Svn Server 强制提交者输入注释信息
  16. Libre Office冻结操作-MAC
  17. 编译x11版本qt
  18. EditPlus 4.3.2560 中文版已经发布
  19. 代理(Proxy)模式简介
  20. Python量化教程 常用函数

热门文章

  1. hibernate学习之持久化对象
  2. OC实现单选和多选按钮
  3. SuperMap iClient 查询成功后如何传递参数?
  4. Java基础学习笔记十三 常用API之正则表达式、Date、DateFormat、Calendar
  5. JavaScript(第二十天)【DOM操作表格及样式】
  6. oralce数据库常用到的一些sql命令(加字段注释,修改数据之类)
  7. C语言第九次作业
  8. django搭建web (三) admin.py -- 待续
  9. Django 模型层
  10. Flask 文件和流