浅笑黄花伊人泪 2014-04-09 20:55
浏览 360
已采纳

Extjs如何调用自定义的panel和代码调用

自己手写一页面的extjs,东拼西凑,刚刚把一个功能完成,居然就有2000代码了,可见垃圾代码不少,不知道怎么将一个js代码分到不同的js文件中,比如Viewport整体布局,上下左右中这5部分想分开写其区域代码 可以吗?如何实现?
另外,一个panel下面 我新建多个panel,我先自定义出去,就像函数调用一样,如何实现呢?谢谢解答!

  • 写回答

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)