Extjs学习笔记之五 一个小细节renderTo和applyTo的区别


Posted in Javascript onJanuary 07, 2010

ExtJS中的renderTo和applyTo的差别

对applyTo和renderTo的理解和思考

个人认为这两篇文章写的不够通俗。写一个简单的例子来看看最终生成了什么代码,

<head> 
<title>RenderTo and ApplyTo</title> 
<link rel="Stylesheet" type="text/css" href="ext-3.1.0/resources/css/ext-all.css" /> 
<script type="text/javascript" src="ext-3.1.0/adapter/ext/ext-base-debug.js"></script> 
<script type="text/javascript" src="ext-3.1.0/ext-all-debug.js"></script> 
<script type="text/javascript" src="ext-3.1.0/src/locale/ext-lang-zh_CN.js"></script> 
<script type="text/javascript"> 
Ext.onReady(function() { 
var button = new Ext.Button({ 
renderTo: 'button', 
text:'OK' 
}); }); 
</script> 
</head> 
<body> 
<div id="button">sadfa</div> 
</body> 
</html>

此代码生成的html如下:
Extjs学习笔记之五 一个小细节renderTo和applyTo的区别 
如果是applyTo:button,则生成的代码为:

Extjs学习笔记之五 一个小细节renderTo和applyTo的区别

很明显,简单的说,applyTo是将组件加在了指定元素之后,而renderTo则是加在指定元素之内

接下来,我们再稍稍探寻下extjs源码的奥秘。看看extjs内部是如何使用这两个配置项的,利用firebug插件调试一下ext-all-debug.js这个文件。

在Ext.Component的构造函数Ext.Component = function(config){…}中有这样一段代码(3.1.0版本是9270行):

if(this.applyTo){ 
this.applyToMarkup(this.applyTo); 
delete this.applyTo; 
}else if(this.renderTo){ 
this.render(this.renderTo); 
delete this.renderTo; 
}

可见applyTo属性使得Component调用applyToMarkup方法,而renderTo使得它调用render方法,并且如果两个都设置的话仅有applyTo有效,这点在extjs的文档中也有特别指出。

appylToMarkup方法如下(3.1.0版本是9560行),

applyToMarkup : function(el){ 
this.allowDomMove = false; 
this.el = Ext.get(el); 
this.render(this.el.dom.parentNode); 
}

它最终调用的也是render,不过render的位置是parentNode,render方法如下(3.1.0版本是9370行)
render : function(container, position){ 
if(!this.rendered && this.fireEvent('beforerender', this) !== false){ 
if(!container && this.el){ 
this.el = Ext.get(this.el); 
container = this.el.dom.parentNode; 
this.allowDomMove = false; 
} 
this.container = Ext.get(container); 
if(this.ctCls){ 
this.container.addClass(this.ctCls); 
} 
this.rendered = true; 
if(position !== undefined){ 
if(Ext.isNumber(position)){ 
position = this.container.dom.childNodes[position]; 
}else{ 
position = Ext.getDom(position); 
} 
} 
this.onRender(this.container, position || null); 
if(this.autoShow){ 
this.el.removeClass(['x-hidden','x-hide-' + this.hideMode]); 
} 
if(this.cls){ 
this.el.addClass(this.cls); 
delete this.cls; 
} 
if(this.style){ 
this.el.applyStyles(this.style); 
delete this.style; 
} 
if(this.overCls){ 
this.el.addClassOnOver(this.overCls); 
} 
this.fireEvent('render', this); var contentTarget = this.getContentTarget(); 
if (this.html){ 
contentTarget.update(Ext.DomHelper.markup(this.html)); 
delete this.html; 
} 
if (this.contentEl){ 
var ce = Ext.getDom(this.contentEl); 
Ext.fly(ce).removeClass(['x-hidden', 'x-hide-display']); 
contentTarget.appendChild(ce); 
} 
if (this.tpl) { 
if (!this.tpl.compile) { 
this.tpl = new Ext.XTemplate(this.tpl); 
} 
if (this.data) { 
this.tpl[this.tplWriteMode](contentTarget, this.data); 
delete this.data; 
} 
} 
this.afterRender(this.container); 
if(this.hidden){ 
this.doHide(); 
} 
if(this.disabled){ 
this.disable(true); 
} 
if(this.stateful !== false){ 
this.initStateEvents(); 
} 
this.fireEvent('afterrender', this); 
} 
return this; 
}

render方法看起来比较复杂,仔细阅读下其实也不是太难,主要就是为一个DOM节点设置class,可见性,在onRender方法中会对这个组件生成相应的html代码。
对applyTo和renderTo的理解和思考 中提到的el配置属性,我查extjs的文档发现这是一个只读属性,虽然有方法覆盖它,不过一般不需要手动设置,下面是Panel的公共属性el的文档原文:

el : Ext.Element

The Ext.Element which encapsulates this Component. Read-only.

This will usually be a <DIV> element created by the class's onRender method, but that may be overridden using the autoEl config.

Note: this element will not be available until this Component has been rendered.

所以我估计此文写的是以前版本的extjs。个人认为,el是紧包裹着extjs组件的一个DOM节点,一般是由extjs自己生成的,好像细胞膜一样,如果拨开了它,那么这个组件就不完整了,很可能会表现的不正常。而render方法中的container(也就是applyTo中指定元素的父元素,renderTo中指定的元素),是该组件的父元素,这个container中可以包括其他的html元素或者extjs组件。

综上所述,其实applyTo和renderTo没有很本质区别,只是render的位置不同。

Javascript 相关文章推荐
JavaScript中valueOf函数与toString方法深入理解
Dec 02 Javascript
封装了一个支持匿名函数的Javascript事件监听器
Jun 05 Javascript
javascript中setInterval的用法
Jul 19 Javascript
JQuery标签页效果实例详解
Dec 24 Javascript
ES2015 Symbol 一种绝不重复的值
Dec 25 Javascript
详解JS中的立即执行函数
Feb 24 Javascript
微信小程序 ecshop地址三级联动实现实例代码
Feb 28 Javascript
Vue.js数据绑定之data属性
Jul 07 Javascript
解决vue项目使用font-awesome,build后路径的问题
Sep 01 Javascript
vue填坑之webpack run build 静态资源找不到的解决方法
Sep 03 Javascript
jquery实现异步文件上传ajaxfileupload.js
Oct 23 jQuery
js实现上传图片到服务器
Apr 11 Javascript
EXT中xtype的含义分析
Jan 07 #Javascript
Extjs学习笔记之四 工具栏和菜单
Jan 07 #Javascript
Extjs学习笔记之三 extjs form更多的表单项
Jan 07 #Javascript
Extjs学习笔记之二 初识Extjs之Form
Jan 07 #Javascript
Extjs学习笔记之一 初识Extjs之MessageBox
Jan 07 #Javascript
jQuery DOM操作小结与实例
Jan 07 #Javascript
javascript当onmousedown、onmouseup、onclick同时应用于同一个标签节点Element
Jan 05 #Javascript
You might like
《雄兵连》系列首部大电影《烈阳天道》:可能是因为期望值太高了
2020/08/18 国漫
PHP个人网站架设连环讲(四)
2006/10/09 PHP
彻底杜绝PHP的session cookie错误
2009/08/09 PHP
『PHP』PHP截断函数mb_substr()使用介绍
2013/04/22 PHP
php使用cookie实现记住用户名和密码实现代码
2015/04/27 PHP
PHP从尾到头打印链表实例讲解
2018/09/27 PHP
js 关键词高亮(根据ID/tag高亮关键字)案例介绍
2013/01/21 Javascript
jQuery手机浏览器中拖拽动作的艰难性分析
2015/02/04 Javascript
javascript中字体浮动效果的简单实例演示
2015/11/18 Javascript
js实现分割上传大文件
2016/03/09 Javascript
js实现内容显示并使用json传输数据
2016/03/16 Javascript
Angularjs分页查询的实现
2017/02/24 Javascript
JavaScript中的return布尔值的用法和原理解析
2017/08/14 Javascript
详解Vue单元测试case写法
2018/05/24 Javascript
浅谈vue获得后台数据无法显示到table上面的坑
2020/08/13 Javascript
Python中使用Tkinter模块创建GUI程序实例
2015/01/14 Python
Python探索之静态方法和类方法的区别详解
2017/10/27 Python
Python实现将一个正整数分解质因数的方法分析
2017/12/14 Python
Django中Model的使用方法教程
2018/03/07 Python
取numpy数组的某几行某几列方法
2018/04/03 Python
windows下python和pip安装教程
2018/05/25 Python
Python3 关于pycharm自动导入包快捷设置的方法
2019/01/16 Python
Python Pillow Image Invert
2019/01/22 Python
解决python 上传图片限制格式问题
2019/10/30 Python
PyTorch在Windows环境搭建的方法步骤
2020/05/12 Python
css3如何绘制一个圆圆的loading转圈动画
2018/01/09 HTML / CSS
html5理解head_动力节点Java学院整理
2017/07/13 HTML / CSS
印尼最大的在线购物网站:MatahariMall.com
2016/08/26 全球购物
Reebonz中国官网:新加坡奢侈品购物网站
2017/03/17 全球购物
自我评价个人范文
2013/12/16 职场文书
消防安全汇报材料
2014/02/08 职场文书
给老师的一封建议书
2014/03/13 职场文书
教育项目合作协议书格式
2014/10/17 职场文书
2015年监理工作总结范文
2015/04/07 职场文书
2015初中政教处工作总结
2015/07/21 职场文书
唤醒紫霞仙子,携手再游三界!大话手游X《大话西游》电影合作专属剧情任务
2022/04/03 其他游戏