介绍DOM1中底层的一些属性和方法。

节点操作

appendChild()

  parentNode.appendChild(newNode)  在parentNode节点的最后插入newNode

insertBefore()

  parentNode.insertBefore(newNode,someNode)  在parentNode节点里面的someNode节点前插入新节点newNode

replaceChild()

  parentNode.replaceChild(newNode,someNode)  在parentNode节点里面把someNode节点替换成newNode

removeChild()

  parentNode.removeChild(someNode)  在parentNode节点里删除指定的节点someNode

cloneNode()

  someNode.cloneNode(true)  创建someNode这个节点的副本,传一个参数,布尔值,true表示深复制,复制整个节点树。false表示浅复制,只复制节点本身。节点复制后,还需要使用appendChild,insertBefore等方法额外添加文档中。

document对象

document.documentElement属性指html元素

document.body属性指body元素

document.url  页面完整的url

document.domain    页面的域名

document.referrer   链接到当前页面的之前那个页面的url

document.getElementById(id)   根据ID查找元素,页面ID需唯一

document.getElementsByClassName(name)   查找class="name"的元素列表,返回HTMLCollection对象

document.getElementsByTagName(name)   根据标签名name查找的元素列表,返回HTMLCollection对象

document.getElementsByName(name)   根据name=“name”查找的元素列表,返回HTMLCollection对象

document.forms   文档中所有的表单

document.images  文档中所有的img标签

document.links   文档中所有带href的a标签

document.write()   文档中写入内容

Element类型

eg:elem为某个元素

elem.id    元素elem在文档中的id

elem.title   元素elem的title属性

elem.className   元素elem的class名称

elem.getAttribute(name)   获得元素elem的属性名为name的值,自定义属性需要通过getAttribute()方法来获得,其他情况通过使用对象的属性来获得,比如elem.title等。

elem.setAttribute(name,'value')  给元素elem设置属性为name的值,值为value

elem.removeAttribute(name)  彻底删除元素elelm的特性name

elem.childNodes    指该元素elem的所有子节点

elem.children   指该元素elem的所有元素子节点

document.createElement(tagName)   创建标签名为tagName的新元素节点

document.createTextNode(text)   创建新的文本节点,文本内容为经过html编码的text

elem.normalize()   将相邻文本节点合并的方法

elem.splitText(index)   与normalize()方法相反,将文本节点分开的方法。index为分开的文本的索引值。

DocumentFragment类型

DocumentFragment指文档片段,在文档中没有对应的标记,不占用额外资源。

document.createDocumentFragment()   创建文档片段

内容操作

elem.innerText    指该元素的所有文本内容

elem.textContent    跟innerText一样,兼容firefox,safari,opera,chrome

elem.innerHTML    返回当前元素elem的所有子节点的html代码

  在IE中,当用innerHTML插入script或style标签时,需要在前面加上标签,使其由作用域外的元素变为作用域内的元素。如:div.innerHTML = '<input type="hidden"><script defer>alert(\'aa\')</scri' + 'pt>';

  在chrome,safari中,需要将style标签添加到head元素中。document.head.appendChild(div);

elem.outerText

elem.outerHTML   写入时,这两个属性会修改调用它的元素

创建table表格

eg:

//创建table

var table = document.createElement('table');

table.border = 1;

table.width = '100%';

//创建tbody

var tbody = document.createElement('tbody');

table.appendChild(tbody);

//创建第一行

tbody.insertRow(0);

tbody.rows[0].insertCell(0);

tbody.rows[0].insertCell(1);

tbody.rows[0].cells[0].appendChild(document.createTextNode('cell 1.1'));

tbody.rows[0].cells[1].appendChild(document.createTextNode('cell 1.2'));

//创建第二行

tbody.insertRow(1);

tbody.rows[1].insertCell(0);

tbody.rows[1].insertCell(1);

tbody.rows[1].cells[0].appendChild(document.createTextNode('cell 2.1'));

tbody.rows[1].cells[1].appendChild(document.createTextNode('cell 2.2'));

DOM操作往往是JS程序开销中最大的部分,包括查询,重排重绘等,所以应尽量避免DOM的频繁操作。

JS 之DOM对象(1)的更多相关文章

  1. js的DOM对象

    1.js的Array对象           ** 创建数组(三种)                          - var arr1 = [1,2,3];                    ...

  2. JavaScript基础15——js的DOM对象

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  3. jQuery对象与JS原生dom对象之间的转换

    jQuery就是JS的一个扩展库,工具库,提供很多方便快捷的方法,所以将JS对象转换为jQuery对象后,能更方便地操作这个对象.但是jQuery对象也不是万能的,有一些JS对象有的能,jQuery对 ...

  4. js操作DOM对象

    js操作DOM对象  (Document Object Model)文档对象模型 nodeType返回值 1:元素节点 2:属性节点 3:文本节点 8:注释节点 9: 文档节点 nodeName 节点 ...

  5. js的dom对象(带实例超详细全解)

    js的dom对象(带实例超详细全解) 一.总结 一句话总结: 1.DOM中的方法区分大小写么? 解答:区分 2.DOM中元素和节点的关系式什么? 解答:元素就是标签,节点中有元素节点,也是标签,节点中 ...

  6. 前端之JavaScript:JS之DOM对象三

    js之DOM对象三   一.JS中for循环遍历测试 for循环遍历有两种 第一种:是有条件的那种,例如    for(var i = 0;i<ele.length;i++){} 第二种:for ...

  7. 前端之JavaScript:JS之DOM对象二

    继续JS之DOM对象二 前面在JS之DOM中我们知道了属性操作,下面我们来了解一下节点操作.很重要!! 一.节点操作 创建节点:var ele_a = document.createElement(' ...

  8. 前端之JavaScript:JS之DOM对象一

    js之DOM对象一 一.什么是HTML  DOM HTML  Document Object Model(文档对象模型) HTML DOM 定义了访问和操作HTML文档的标准方法 HTML DOM 把 ...

  9. 转:js包装DOM对象

    我们在日常的应用中,使用Javascript大多数时间都是在用DOM ,以致于很多人都有一种看法就是DOM==JS,虽然这种看法是错误的,但是也可以说明DOM的重要性. 这就导致了我们在写JS的时候, ...

  10. 继续JS之DOM对象二

    前面在JS之DOM中我们知道了属性操作,下面我们来了解一下节点操作.很重要!! 一.节点操作 创建节点:var ele_a = document.createElement('a');添加节点:ele ...

随机推荐

  1. C++语言-03-类与对象

    类 类是面向对象编程中的核心概念,用于定义一个数据类型的蓝图,描述类的对象包括什么,以及可以在这些对象上执行那些操作. 类的成员 数据成员 描述数据的表示方法 class ClassName { ac ...

  2. 深入掌握Java中的enum

    对于要在程序中要表示有限种类的某事物,一般我们可以采用两种方式,一是使用:public static final String 常量:二是使用enum来表示.一般而言前者简单,但是不能够很好的提供更多 ...

  3. 使用Spring Security Oauth2完成RESTful服务password认证的过程

            摘要:Spring Security与Oauth2整合步骤中详细描述了使用过程,但它对于入门者有些重量级,比如将用户信息.ClientDetails.token存入数据库而非内存.配置 ...

  4. Safari5及以下版本不支持Date的横杠字符串格式

    Date构造器有多种方式创建方式 一.new Date() // 当天 var date = new Date() 二.new Date(value) // value 为一个整数 var date ...

  5. python django 与数据库的交互

    下载没有任何问题的mysqdb http://www.codegood.com/archives/4 1创建一个新的app. python manage.py startapp books 2 激活a ...

  6. uva 725 division(水题)——yhx

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABVMAAAOHCAIAAAClwESxAAAgAElEQVR4nOydybGturJFcQEPfgQu4A

  7. Hog SVM 车辆 行人检测

    HOG SVM 车辆检测 近期需要对卡口车辆的车脸进行检测,首先选用一个常规的检测方法即是hog特征与SVM,Hog特征是由dalal在2005年提出的用于道路中行人检测的方法,并且取的了不错的识别效 ...

  8. 分享一个解决MySQL写入中文乱码的方法

    分享一个解决MySQL写入中文乱码的方法 之前有发帖请教过如何解决MySQL写入中文乱码的问题.但没人会,或者是会的人不想回答.搜索网上的答案并尝试很多次无效,所以当时就因为这个乱码问题搁浅了一个软件 ...

  9. web前端笔试题总结

    em和rem的区别: 浏览器的默认字体高度是16px,1em=16px:大小可以自己设置调整,并且默认集成父级容器中文本的大小. rem是CSS3中新增的属性,默认情况下是文本尺寸的大小,不同的是它集 ...

  10. PHP中的include和require

    1.include语句 使用include语句可以告诉PHP提取特定的文件,并载入它的全部内容 <?php inlude "fileinfo.php"; //此处添加其他代码 ...