问题描述
自己手写一页面的extjs,东拼西凑,刚刚把一个功能完成,居然就有2000代码了,可见垃圾代码不少,不知道怎么将一个js代码分到不同的js文件中,比如Viewport整体布局,上下左右中这5部分想分开写其区域代码 可以吗?如何实现?另外,一个panel下面 我新建多个panel,我先自定义出去,就像函数调用一样,如何实现呢?谢谢解答!
解决方案
当然得这么写…… 初学可以放在一起,真正做项目一定得分开。。你的思路非常正确首先你必然有一个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传参的形式也可以做到。