javascript复制对象使用说明
oldObj是一个对象,而不是值
例如var newObj=oldObj;
如果想oldObj改变的时候不影响到newObj;
可以这样写一个函数
然后这样调用
newObj=clone(oldObj)
之后,oldObj的值无论怎么改变都不会影响newObj
JavaScript复制对象
语法:
oElement = object . cloneNode ( bCloneChildren )
参数:
bCloneChildren : 可选项。布尔值(Boolean)。false | true
false : 默认值。克隆 object 时不包括 object 的 childNodes 集合。即其所有子对象。
true : 克隆 object 时包括 object 的 childNodes 集合。即其所有子对象。
返回值:
oElement : 对象(Element)。返回克隆后的新对象的引用。
说明:
在文档结构中克隆 object 。
克隆后,获取克隆对象的 id 时,将返回一个集合。
在运行时使用此方法是可以的。在对象的关闭标签被解析前,文档空间可能不能被呈递。
示例代码:
例如var newObj=oldObj;
如果想oldObj改变的时候不影响到newObj;
可以这样写一个函数
function clone(myObj){
if(typeof(myObj) != 'object') return myObj;
if(myObj == null) return myObj;
var myNewObj = new Object();
for(var i in myObj)
myNewObj[i] = clone(myObj[i]);
return myNewObj;
}
然后这样调用
newObj=clone(oldObj)
之后,oldObj的值无论怎么改变都不会影响newObj
JavaScript复制对象
语法:
oElement = object . cloneNode ( bCloneChildren )
参数:
bCloneChildren : 可选项。布尔值(Boolean)。false | true
false : 默认值。克隆 object 时不包括 object 的 childNodes 集合。即其所有子对象。
true : 克隆 object 时包括 object 的 childNodes 集合。即其所有子对象。
返回值:
oElement : 对象(Element)。返回克隆后的新对象的引用。
说明:
在文档结构中克隆 object 。
克隆后,获取克隆对象的 id 时,将返回一个集合。
在运行时使用此方法是可以的。在对象的关闭标签被解析前,文档空间可能不能被呈递。
示例代码:
<script>
function rdl_fnClone(){
var oCloneNode=oList.cloneNode(true);
cloneArea.appendChild(oCloneNode);
}
</script>
<table width=98%><tr><td>
<ul id=oList>
<li>第1个列表项目
<li>第2个<a href="#" onclick="return false;">列表项目</a>
<li style="font-weight:bold;">第3个列表项目
</ul>
</td><td id=cloneArea>
</td></tr></table>
<input type=button value=" 克隆 " onclick= "rdl_fnClone();">
javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)
关于javascript中类的继承可以参考阮一峰的Blog《Javascript继承机制的设计思想》,说的很透。一、在javascript中实例化遇到的问题:下面用《javascript高级
JS继承 笔记
JS继承JavaScript中没有类的概念,与类相关的继承的概念更是无从谈起,但是我们可以通过特殊的语法来模拟面向对象语言中的继承。在JS中模拟继承有
Javascript 面向对象编程(一) 封装
学习Javascript,最难的地方是什么?我觉得,Object(对象)最难。因为Javascript的Object模型很独特,和其他语言都不一样,初学者不容易掌握。下面就是我