JS中迭代元素特性

  在需要将DOM结构序列化为XML或者HTML字符串时,多数都会涉及遍历元素的特性,这个时候attributes属性就可以派上用场。

  以下代码展示了如何迭代元素的每一个特性,然后将他们构造成 name = "value"  name = "value" 这样的字符串格式。

function outputAttributes(element)
{
var pairs = new Array();
for(var i=0, len=element.attributes.length; i < len; i++)
{
var attrName = element.attributes[i].nodeName;
var attrValue = element.attributes[i].nodeValue;
pairs.push(attrName + "=\"" + attrValue + "\"");
}
return pairs.join(" ");
}

  通过attributes.length属性,for循环会遍历每个特性,将特性的名称和值输出为字符串。这个函数使用了一个数组保存名值对,最后再以空格为分隔符将它们拼接起来(这是序列化长字符串一种常用的技巧)。

  关于上面代码运行结果,有两点声明:

  • 针对attributes对象中的特性,不同浏览器返回的顺序不同,这些特性在XML中或HTML代码中出现的先后顺序,不一定与它们出现在attributes对象中的顺序一致。
  • IE7及更早的版本中会返回HTML元素中所有可能的特性,包括没有指定的特性,也可以说返回100多个特性的情况也是可以有的。

  针对IE7及更早的版本中存在的问题,可以对上面函数加以改进,让它只返回特定的特性。每个特性节点都有一个specified的属性,这个属性如果为true,意味着要么在HTML中指定了相应的特性,要么通过setAttribute() 方法设置了该特性,在IE中,所有未设置的特性的该属性都为false,而在其他浏览器中根本不会为这类特性生成对应的特性节点,因此,在这些浏览器中,任何特性节点的specified的值始终为true。

  改进后的代码如下:

function outputAttributes(element)
{
var pairs = new Array();
for(var i=0, len=element.attributes.length; i < len; i++)
{
var attrName = element.attributes[i].nodeName;
var attrValue = element.attributes[i].nodeValue;
if (element.attributes[i].specified)
{
pairs.push(attrName + "=\"" + attrValue + "\"");
} }
return pairs.join(" ");
}

  这样改进后的函数可以确保即使在IE7及更早的版本中,也会返回指定的特性。

DOM中的DocumentFragment类型

  先来看一个HTML例子:

<ul id="mylist"></ul>

  当我们想为这个<ul>元素添加3个列表项,如果逐个地添加列表项,将会导致浏览器反复渲染(呈现)新的信息,为了避免这个问题,可以使用一个文档片段(document fragment)来保存创建的列表项,然后再一次性的将三个列表项添加到文档中。

  DOM规定文档片段是一种“轻量级”的文档,可以包含和控制节点,但不会像完整文档那样占用额外的资源,也就是不能把文档片段直接添加到文档中,不过可以把它作为一个“仓库”使用,在里面保存将来可能添加到文档中的节点,比如上例中的三个列表项。

  文档片段继承了Node的所有方法,通常用于执行那些针对文档的DOM操作。如果将文档中的节点添加到文档片段中,就会从文档树中移除该节点,也不会从浏览器中再看到该节点。添加到文档片段中的新节点也不再属于文档树。可以通过 appendChild() 或者 insetBefore() 将文档片段中内容添加到文档中。在将文档片段作为参数传递给这两个方法时,实际上只会将文档片段内部的节点添加到文档树中的相应位置,而文档片段本身是不可能成为文档树的一部分。

  要想创建一个 文档片段,可以使用document.createDocumentFragment()方法。如下:

var fragment = document.createDocumentFragment();

 

  利用文档片段来解决上述的例子:

var fragment = document.createDocumentFragment();  //创建文档片段
var ul = document.getElementById("myLisst");
var li = null; for(var i=0; i < 3; i++){
li = document.createElement("li"); //创建文本节点
li.appendChild(document.createTextNode("Item "+(i+1))); //把文本节点添加到<li>元素
fragment.appendChild(li) //使用appendChild()将li添加到文本片段中
}
ul.appendChild(fragment); //最后一次性把文档片段中的所有子节点转移到<ul>中

以上内容参考自:javascript高级程序设计

js中迭代元素特性与DOM中的DocumentFragment类型 笔记的更多相关文章

  1. js判断一个元素是否在数组中

    js判断一个元素是否在数组中 var arr = ['a','s','d','f']; console.info(isInArray(arr,'a'));//循环的方式 function isInAr ...

  2. JQ中的clone()方法与DOM中的cloneNode()方法

    JQ中的clone()方法与DOM中的cloneNode()方法 cloneNode()定义和用法 cloneNode()方法创建节点的拷贝,并返回该副本. 语法: node.cloneNode(de ...

  3. 关于js全局变量数组push数据时dom中无数据的问题

    今天着实悲催,这问题整了好几个小时才解决.废话不多说,上问题. 一开始我定义了许多全局变量放在me下. var me = { dgOrderDetails: null, dgVisitNumbers: ...

  4. Python:将数组中的元素导出到变量中 (unpacking)

    问题 你需要将数组(list)或元组(tuple)中的元素导出到N个变量中. 解决方案 任何序列都可以通过简单的变量赋值方式将其元素分配到对应的变量中,唯一的要求就是变量的数量和结构需要和序列中的结构 ...

  5. 了解数组中的队列方法,DOM中节点的一些操作

    队列的概念 栈是一种后进先出的结构,而队列是一种先进先出的结构.如银行排队,排在前面的人先办业务然后离开,后来的人站在最后.可以用队列的push()方法插入元素到队列的末尾,可以用shift()方法删 ...

  6. React-将元素渲染到 DOM 中

    首先我们在一个 HTML 页面中添加一个 id="root" 的 <div>,在此 div 中的所有内容都将由 React DOM 来管理,所以我们将其称之为 “根” ...

  7. js获取iframe中的元素以及在iframe中获取父级的元素(包括iframe中不存在name和id的情况)

      第一种情况:iframe中不存在name和id的方法:(通过contentWindow获取) var iframe = document.getElementsByTagName('iframe' ...

  8. O(1)时间复杂度实现入栈、出栈、获得栈中最小元素、获得栈中最大元素(转)

    题目要求:定义栈的数据结构,添加min().max()函数(动态获取当前状态栈中的最小元素.最大元素),要求push().pop().min().max()的时间复杂度都是O(1). 思路解析:根据栈 ...

  9. 删除列表中重复元素以及求list中元素个数

    Python 去除列表中重复的元素 来自比较容易记忆的是用内置的set l1 = ['b','c','d','b','c','a','a'] l2 = list(set(l1)) print l2 还 ...

随机推荐

  1. Python基础—16-网络编程

    网络编程 相关概念 OSI七层模型:开放系统互连参考模型.它从低到高分别是:物理层.数据链路层.网络层.传输层.会话层.表示层和应用层. TCP/IP:在OSI七层模型的基础上简化抽象出来的一套网络协 ...

  2. aes 加密,解密(2)

    JavaScript加密,解密 1,此为AES加密后,转换为16进制编码 var encodePwd = function (data,key){ var keyHex = CryptoJS.enc. ...

  3. POJ 1410--Intersection(判断线段和矩形相交)

    Intersection Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 16322   Accepted: 4213 Des ...

  4. 新疆大学ACM-ICPC程序设计竞赛五月月赛(同步赛)-B-杨老师游戏

    题目链接:杨老师游戏 题目分析:将9个数字分成3块,分块枚举,话句话说,9个数字的所有排列组合,如果满足N=a*b-c就是一个答案,暴力枚举Orz. 代码如下:  #include<iostre ...

  5. C++求值顺序

    <C++Primer5th>中文版第124页 C++语言没有明确规定大多数二元运算符的求值顺序, 给编译器优化留下了余地. 这种策略实际上是在代码生成效率和程序潜在缺陷之间进行了权衡,这个 ...

  6. python list统计

    from random import randint data = [randint(0, 20) for _ in xrange(30)] print data # [20, 4, 4, 20, 1 ...

  7. Linux centos7 安装python3 及 GCC

    1.用wget下载python源码 PYTHON下载 找适合自己的版本,我下载的是3.7.2 2.用tar命令解压下载的文件 tar -zxvf Python-3.7.2.tgz 3.进入目录解压后的 ...

  8. Docker 运行MySQL 5.7

    #在opt新建挂载目录 cd /opt #-v 显示创建的目录名 mkdir -vp docker_cfg/mysql/data docker_cfg/mysql/logs docker_cfg/my ...

  9. Co. - Apple - MacBook Pro 快捷键

    Mac 键盘快捷键:https://support.apple.com/zh-cn/HT201236 从windows转到mac的童鞋,可能删除键是心中的一个痛,以前习惯一按delete什么都消失,其 ...

  10. ubuntu以root进入图形化界面

    sudo nautilus 可以进行一些文件夹移动操作,不会出现权限的问题