ExtJs–13– Ext.apply(src,apply) 和 Ext.applyIf(src,apply) 兩個方法的使用和區別比較

Ext.onReady(function(){
	
	/*
	 * Ext.apply(src,apply) 和 Ext.applyIf(src,apply) 兩個方法的使用和區別比較
	 */
	
	
	//Ext.apply(src,apply)方法用於擴展和修改原有對象的屬性或方法
	//定義對象src
	var src = {name:"tom",age:22};
	//定義對象apply
	var apply= {sex:"男",age:33,name:"jack",sal:10000};
	//使用Ext.apply方法對src對象進行屬性擴展  或方法擴展
	Ext.apply(src,apply);
	//
	//查看src多有的屬性和屬性值
	for(var attr in src ){
		document.write(attr +"--"+src[attr])
		document.write("
") } //結果如下 //name--jack //age--33 //sex--男 //sal--10000 //從源代碼和測試結果可以看出: //用apply對象中的屬性和src對象中屬性進行逐個比較,如果在src中不存在該屬性就賦值復制到src中,如果有相同屬性,就覆蓋原有屬性的值 //Ext.apply方法擴展之後的結果就為上面的測試結果瞭 //***************分隔線*********************** document.write("
") //Ext.applyIf(src,apply)和Ext.apply(src,apply)的區別在於 //如果原對象中存在當前正在比較的屬性,那麼就不進行復制瞭,多以當然就不會修改該屬性的值瞭 // 例如: var srcif = {name:"tom",age:22}; var applyif= {sex:"男",age:33,name:"jack",sal:10000}; Ext.applyIf(srcif,applyif); for(var attr in srcif){ document.write(attr+"----"+srcif[attr]) document.write("
") } //結果是 //name----tom //age----22 //sex----男 //sal----10000 })

發佈留言