自己手写一页面的extjs,东拼西凑,刚刚把一个功能完成,居然就有2000代码了,可见垃圾代码不少,不知道怎么将一个js代码分到不同的js文件中,比如Viewport整体布局,上下左右中这5部分想分开写其区域代码 可以吗?如何实现?
另外,一个panel下面 我新建多个panel,我先自定义出去,就像函数调用一样,如何实现呢?谢谢解答!
Extjs如何调用自定义的panel和代码调用
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- zuoshang 2014-04-10 18:06关注
当然得这么写…… 初学可以放在一起,真正做项目一定得分开。。你的思路非常正确
首先你必然有一个html页面(当然或许是jsp),在这个页面上当然是导入一堆js css文件吧,于是你分离开的js文件也在这里导入。
先说一种比较直白
比如你的 A.js里是你的viewport,你想把内部某一个panel写到B.js里,那么你在B.js里第一行直接开始var b_panel = new Ext.Panel({...}),创建出你的panel对象,然后在你的 A.js里,就直接可以用b_panel这个对象塞进viewport的items里。
注意:在html页面中导入js的顺序要正确,就是B.js要在 A.js前面加载。
原理就是:随着一排js的导入,每个js文件里new出的对象都会存放在内存中, 前面创建出的后面都可以用,所以B.js里创建的b_panel可以在 A.js里直接使用。
一个变种就是在B.js里的new代码外面包一层function,作为函数调用。然后你可以在任何需要的地方去调用这个function,这样你可以new出多个panel实例(当然,需要的话)。当然更好的办法是将你要分离出去的panel,作为Ext.Panel的子类,用继承语法定义成一个类,这样你在需要使用的地方可以像new Ext.YourPanel({...})这样Ext风格创建出,比较正规。项目中必然会遇到一些可以复用的组件,形式相似的组件,这时候定义类的优势不言而喻。当然用定义function传参的形式也可以做到。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 安卓adb backup备份应用数据失败
- ¥15 eclipse运行项目时遇到的问题
- ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
- ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
- ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
- ¥50 成都蓉城足球俱乐部小程序抢票
- ¥15 yolov7训练自己的数据集
- ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
- ¥15 电力市场出清matlab yalmip kkt 双层优化问题
- ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)