资讯专栏INFORMATION COLUMN

JavaScript DOM——“DOM操作技术”的注意要点

ckllj / 2710人阅读

摘要:在遍历的时候很容易犯这样的错误这是一个无限循环,因为是动态的实时更新的。应该把属性初始化第二个变量应该尽量减少访问的次数因为每次访问都会运行依次基于文档的查询所以应该考虑将从中提取出的值缓存起来。

动态脚本 插入外部脚本文件

script元素为例:


使用DOM动态的创建出这个元素:

function loadScript(url) {
    var script = document.createElement("script");
    script.type = "text/javascript";
    script.src = url;
    document.body.appendChild(script);
}
loadScript("client.js")
行内方式插入脚本文件

以行内脚本代码为例:


使用DOM动态的创建出这个元素:

var script = document.createElement("script");
script.type = "text/javascript";
script.appendChild(document.createTextNode("function sayHi(){alert("hi");}"));
document.body.appendChild(script);

但在IE中会报错,解决办法是使用script元素的text属性:

var script = document.createElement("script");
script.type = "text/javascript";
script.text = "function sayHi(){alert("hi");}";
document.body.appendChild(script);

最终通用的解决方案如下:

function loadScriptString(code) {
    var script = document.createElement("script");
    script.type = "text/javascript";
    try {
        script.appendChild(document.createTextNode(code));
    } catch (ex) {
        script.text = code;
    }
    document.body.appendChild(script);
}
loadScriptString("function sayHi(){alert("hi");}");

实际上在全局作用域中把相同的字符串传递给eval()是一样的。

动态样式 link元素包含来自外部的文件

link元素为例:


使用DOM动态的创建出这个元素:

function loadStyles(url) {
    var link = document.createElement("link");
    link.rel = "stylesheet";
    link.type = "text/css";
    link.href = url;
    var head = document.getElementsByTagName("head")[0];
    head.appendChild(link);
}
loadStyles("style.css");
style元素来指定嵌入的样式

以嵌入样式为例:


使用DOM动态的创建出这个元素:

var style = document.createElement("style");
style.type = "text/css";
style.appendChild(document.createTextNode("body{background-color:red}"));
var head = document.getElementsByTagName("head")[0];
head.appendChild(style);

但在IE中会报错,解决办法是访问元素的styleSheet属性的cssText属性:

var style = document.createElement("style");
style.type = "text/css";
try{
    style.appendChild(document.createTextNode("body{background-color:red}"));
}catch(ex){
    style.styleSheet.cssText = "body{background-color:red}";
}
var head = document.getElementsByTagName("head")[0];
head.appendChild(style);

最终通用的解决方案如下:

function loadStyleString(css) {
    var style = document.createElement("style");
    style.type = "text/css";
    try {
        style.appendChild(document.createTextNode(css));
    } catch (ex) {
        style.styleSheet.cssText = css;
    }
    var head = document.getElementsByTagName("head")[0];
    head.appendChild(style);
}
loadStyleString("body{background-color:red}");
操作表格

HTML表格为例:

Cell 1,1 Cell 2,1
Cell 1,2 Cell 2,2

传统上需要如下大量的DOM代码:

//创建table
var table = document.createElement("table");
table.border = "1";
table.width = "100%";

//创建tbody
var tbody = document.createElement("tbody");
table.appendChild(tbody);

//创建第一行
var row1 = document.createElement("tr");
tbody.appendChild(row1);
var cell1_1 = document.createElement("td");
cell1_1.appendChild(document.createTextNode("Cell 1,1"));
row1.appendChild(cell1_1);
var cell2_1 = document.createElement("td");
cell2_1.appendChild(document.createTextNode("Cell 2,1"));
row1.appendChild(cell2_1);

//创建第二行
var row2 = document.createElement("tr");
tbody.appendChild(row2);
var cell1_2 = document.createElement("td");
cell1_2.appendChild(document.createTextNode("Cell 1,2"));
row2.appendChild(cell1_2);
var cell2_2 = document.createElement("td");
cell2_2.appendChild(document.createTextNode("Cell 2,2"));
row2.appendChild(cell2_2);

//将表格添加到文档主体中
document.body.appendChild(table);

为了方便构建表格,HTML DOM 还为table元素、tbody元素和tr元素添加了一些属性和方法。如

为table元素添加的属性和方法如下:

caption:caption元素的指针(如果有);

tBodies:tbody元素的HTMLCollection;

tFoot:tfoot元素的指针(如果有);

tHead:thead元素的指针(如果有);

rows:一个表格中所有行的HTMLCollection;

createTHead():创建thead元素并将其放入表格中,返回引用;

createTFoot():创建tfoot元素并将其放入表格中,返回引用;

createCaption():创建caption元素并将其放入表格中,返回引用;

deleteTHead():删除thead元素;

deleteTFoot():删除tfoot元素;

11. deleteCaption():删除caption元素;
12. deleteRow(pos):删除指定位置的行;
13. insertRow(pos):插入一行到rows集合中;

为tbody元素添加的属性和方法如下:

deleteRow(pos):删除指定位置的行;

insertRow(pos):插入一行到指定位置的rows集合中;

为tr元素添加的属性和方法如下:

cells:tr元素中单元格的HTMLCollection;

deleteCell(pos):删除指定位置的单元格;

insertCell(pos):插入一个单元格到cells集合中;

使用这些方法和属性可以极大的减少创建表格所需的代码数量,返回对心插入单元格的引入;前面的代码重写如下:

//创建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].cells[0].appendChild(document.createTextNode("Cell 1,1"));
tbody.rows[0].insertCell(1);
tbody.rows[0].cells[1].appendChild(document.createTextNode("Cell 2,1"));

//创建第二行
tbody.insertRow(1);
tbody.rows[1].insertCell(0);
tbody.rows[1].cells[0].appendChild(document.createTextNode("Cell 1,2"));
tbody.rows[1].insertCell(1);
tbody.rows[1].cells[1].appendChild(document.createTextNode("Cell 2,2"));

//将表格添加到文档主体中
document.body.appendChild(table);
使用NodeList

需要理解NodeList以及NamedNodeMapHTMLCollection;这三个集合都是“动态的”;每当文档结构发生变化时,他们都会得到更新。
在遍历NodeList的时候很容易犯这样的错误:

var divs = document.getElementsByTagName("div");
for (var i = 0; i < divs.length; i++) {
    var div = document.createElement("div");
    div.appendChild(document.createTextNode("data"));
    document.body.appendChild(div);
}

这是一个无限循环,因为divs是动态的实时更新的。

应该把length属性初始化第二个变量:

var divs = document.getElementsByTagName("div");
for (var i = 0, len = divs.length; i < len; i++) {
    var div = document.createElement("div");
    div.appendChild(document.createTextNode("data"));
    document.body.appendChild(div);
}

应该尽量减少访问NodeList的次数;因为每次访问NodeList都会运行依次基于文档的查询;所以应该考虑将从NodeList中提取出的值缓存起来。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/78295.html

相关文章

  • React要点入门学习总结

    摘要:上面代码中,通过为组件指定事件的回调函数,确保了只有等到真实发生事件之后,才会读取属性。七表单代码九要点文本输入框的值,不能用读取,而要定义一个事件的回调函数,通过读取用户输入的值。 一.JSX简介 JSX即JavaScript XML,一种在React组件内部构建标签的类XML语法。在不使用JSX的情况下,React程序中创建DOM是这样的: //v0.11 React.DOM.h1...

    Towers 评论0 收藏0
  • JavaScript JavaScript与XML——“XML DOM注意要点

    摘要:如发生解析错误时,仍然会从中返回一个对象。但这个对象的文档元素是对象根元素第一个子元素为。 DOM2级核心 docuent.implementation中引入了createDocument()方法,IE9支持该方法,如: var xmldom = document.implementation.createDocument(namespaceUri, root, doctype); ...

    melody_lql 评论0 收藏0
  • JavaScript JavaScript与XML——“XML DOM注意要点

    摘要:如发生解析错误时,仍然会从中返回一个对象。但这个对象的文档元素是对象根元素第一个子元素为。 DOM2级核心 docuent.implementation中引入了createDocument()方法,IE9支持该方法,如: var xmldom = document.implementation.createDocument(namespaceUri, root, doctype); ...

    figofuture 评论0 收藏0
  • JavaScript DOM扩展——“专有扩展”注意要点

    摘要:另外,以及这两个方法,在测试了一下,并无反应。不知是否兼容问题。下面是获得焦点的时候,自动以每毫秒的速度往下滚屏 文档模式 页面的文档模式是由IE8引入的,文档模式决定了可以使用的CSS级别、JS中的API以及如何对待文档类型(doctype);在IE9,提供了4中文档模式: IE5:混杂模式; IE7:IE7标准模式渲染页面; IE8:IE8标准模式渲染页面,可以使用Selecto...

    wudengzan 评论0 收藏0
  • JavaScript DOM2和DOM3——“DOM变化”注意要点

    摘要:和级分为许多模块,分别描述了的某个非常具体的子集。这些模块主要有核心视图事件样式遍历和范围以及。另外还有方法和方法框架的变化框架和内嵌框架分别用和表示,它们在级中都有一个新属性这个属性包含一个指针,指向表示框架内容的文档对象。 DOM2和DOM3级分为许多模块,分别描述了DOM的某个非常具体的子集。这些模块主要有核心(Core)、视图(Views)、事件(Events)、样式(Styl...

    骞讳护 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<