ExtJS 4.1 TabPanel动态加载页面并执行脚本,写这个东西我写了好几天,但是写完之后就会有满满的成就感,我终于成功了,挺兴奋的,下面就来向大家介绍我写代码的整个过程。
按照官方示例,可以动态加载页面,可是脚本不执行,于是查SDK、google,发现scripts需要设置为true,于是设置该属性,整个代码如下
tabPanel.add({ title: 'dynamic page', closable: true, loader: { 'test.htm', loadMask: 'loading...', autoLoad: true, scripts: true } });
刚开始以为加载页面的脚本写的有问题,因为查了很多资料,有人说要写在6c04bd5ca3fcae76e30b72ad730ca86d里面,有人说只能写在页面上,不能用src引用js文件,但无论怎么试也不行,我的加载页面很简单,只要页面被加载就出弹窗
<script type="text/javascript"> alert("addd"); </script> 后来想,是不是需要在tab被激活的事件手工load,而不是autoLoad,于是再次实验,终于成功了,兴奋! tabPanel.add({ title: 'dynamic page', closable: true, loader: { 'test.htm', loadMask: 'loading...', autoLoad: true, scripts: true } listeners: { activate: function(tab){ tab.loader.load(); } } });
本来想着到此为止,一天时间总算搞定这个tab,但是兴奋之余发现,该做法是有问题的,每次点击tab,都会触发激活事件,去读取后台页面一次,而我想要的效果是,前台加载一次之后,切换tab也不要再访问后台。于是查SDK、google,想在activate事件里,判断tab已经load,但是未果
第二天,去掉了listeners,然后莫名其妙想测试加载页面的loading效果,特意将页面线程阻止,加入以下代码
System.Threading.Thread.Sleep(5000);
这次是无心插柳,发现隔了5秒加载的页面,居然能正常执行脚本了!
我的操作步骤如下:点了加载按钮,然后点击动态加载的tab,该tab无内容,隔了5秒,内容出现,脚本执行
但是被加载的页面不能总是被sleep,于是继续查资料继续试,甚至开始调试extjs的源代码,这里说下如何调试,页面切换以下脚本
<script type="text/javascript" src="/Scripts/ext/ext-all.js?1.1.11"></script>改为 <script type="text/javascript" src="/Scripts/ext/ext-debug.js?1.1.11"></script>
如何调试就不解释了,google多的是,调试了一天,无果。不过对extjs的代码算是有了第一次亲密接触
而且还发现一个奇怪的事情,在调试的时候,就算加入了Sleep(5000),加载的页面脚本也无法执行,越来越纳闷
第三天,狂加QQ群,各论坛网站发帖,继续google,无果
第四天,算是我点幸,用微软的bing搜索autoload:true, scripts:true,出来的第条,就有这样的介绍,不过是讲extjs 4.0的panel如何加载页面执行脚本的,于是按照它的代码测试
Ext.onReady(function () { var panel = Ext.create('Ext.Panel', { title: 'Anchor Layout', renderTo:Ext.getBody(), loader:{ url: "test.htm",autoLoad:true, scripts:true}//加载1.htm页面 }); });
该代码居然能成功执行!这下彻底兴奋了,因为tab可以加载任意的component,当然也可以加载panel,于是修改我的代码
var panel = Ext.create('Ext.Panel',{ title: 'dynamic page', renderTo:Ext.getBody(), closable: true, loader: { 'test.htm', loadMask: 'loading...', autoLoad: true, scripts: true } }); tabPanel.add(panel);
成功了!真的狂喜,花费4天下来,总算是有个好的结果,这种喜悦,只有我们技术人员才能理解到
比较代码差异,发现就少了这么一个配置,就是我上面黄色标出来的,renderTo:Ext.getBody(),居然,居然要被render一下,才能正常显示脚本,为什么SDK没有!!
但是,但是……这也不是一个完美的解决办法,细心的朋友就知道,该脚本会把加载页面首先加载到主页面上,切换tab才会消失,这么严重的问题,因为当时太兴奋,居然没有发现,唉。
不得不停下敲键盘的手,仔细思考起来,我有3次加载页面执行脚本成功,这3次分别是
1、tab被activate的事件中
2、sleep之后点击tab等待页面加载好
3、加入renderTo配置
经过长时间思考,终于发现这3次成功的时候,都有个共同点,加载的页面被显示出来了,也就说,如果tab先load页面,然后再“被看见”,那脚本就不执行了
为了验证我的想法,于是马上动手测试,把sleep设为100毫秒,点击加载按钮,隔了1秒再去看加载出来的tab,果然脚本不执行了!!!
总算找到原因:tab必须先“展现”出来,然后再去load,那这就简单了,马上查SDK,不难发现show这个方法,于是修改代码
tabs.add({ title: 'dynamic page', //renderTo: Ext.getBody(), loader: { url: 'test.htm', loadMask: 'loading...', autoLoad: true, scripts: true } }).show();
OK,脚本正常执行,到此我的问题“完美”解决
以上是动态加载页面并执行的实例详解的详细内容。更多信息请关注PHP中文网其他相关文章!

本文讨论了使用Maven和Gradle进行Java项目管理,构建自动化和依赖性解决方案,以比较其方法和优化策略。

本文使用Maven和Gradle之类的工具讨论了具有适当的版本控制和依赖关系管理的自定义Java库(JAR文件)的创建和使用。

本文讨论了使用咖啡因和Guava缓存在Java中实施多层缓存以提高应用程序性能。它涵盖设置,集成和绩效优势,以及配置和驱逐政策管理最佳PRA

本文讨论了使用JPA进行对象相关映射,并具有高级功能,例如缓存和懒惰加载。它涵盖了设置,实体映射和优化性能的最佳实践,同时突出潜在的陷阱。[159个字符]

Java的类上载涉及使用带有引导,扩展程序和应用程序类负载器的分层系统加载,链接和初始化类。父代授权模型确保首先加载核心类别,从而影响自定义类LOA


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

WebStorm Mac版
好用的JavaScript开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Atom编辑器mac版下载
最流行的的开源编辑器

Dreamweaver CS6
视觉化网页开发工具