DDR爱好者之家 Design By 杰米
现在也有很多JS动态加载的框架,比如In.js。但是这种并不是我想要的编写方式,我来说说我的想法。
先来一段java代码
复制代码 代码如下:
import Biz.User;
User u = new User();
u.show();
按流程就是导包、实例化、调用。
JS是做不了导包的,或者说代码意义上的导包,一般只是在页面上进行script标签的引入。
那么 先假设需要写成这样
复制代码 代码如下:
Using("User");
var u = new User();
u.show();
那么,在JS里面可以实现吗?
来一句一句的分析,当然,前提是页面并不用script标签载入user.js,不然就没意义了。
第一句
Using("User");
为什么用Using,当然只是我的一个命名想法而已,可以联想一下C#,用的就是using,借来而已。
Using里面写入的当然是我需要的对象User,顾名思义,我当然写成Using("User")了。先不说内里是怎么实现的,起码思路是这样。
因为不能模拟关键字写成 Using User;这种起码我是做不到了。
第二句和第三句
复制代码 代码如下:
var u = new User();
u.show();
很正常,就是很平常的实例化与函数调用,唯一不解的是User对象哪里来的?那么当然是第一句导包的时候导入的。
流程就是这么个流程,那么到底能不能实现,关键就在第一句话。也就是说,到底能不能导包成功,而且该怎么导包。
从script标签吸引灵感,对,异步加载所需要的js文件。
也就是说
复制代码 代码如下:
Using("User");
相当于写了一句
复制代码 代码如下:<script type="text/javascript" src="/UploadFiles/2021-04-02/user.js">
现在这么看下来,这么做有意义吗?就为把script标签写成JS动态引入的?或者,只为少写几个字符?
当然不能,这么做毫无意义!那要怎么做?
先从效率来讲。
如果一个页面需要载入N多js文件的时候,如下
复制代码 代码如下:
<script type="text/javascript" src="/UploadFiles/2021-04-02/jquery.min.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/view.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/register.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/validate.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/user.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/order.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/type.js">
等等等等。
是不是很吓人,那是相当吓人,而且后期维护需要很高的成本,有多少页面,可能就需要修改几个页面。那么,当页面只引入关键的几个js文件,其他文件都采用动态载入的方式呢?
比如我们只需要载入jquery文件,然后调用
复制代码 代码如下:
$.getScript("user.js",function(){});
这样,我们就做到页面文件里面只需要引入
复制代码 代码如下:
<script type="text/javascript" src="/UploadFiles/2021-04-02/jquery.min.js">
即可。
那么这种写法的坏处在哪里?看一段代码
复制代码 代码如下:
$.getScript("user.js",function(){
$.getScript("order.js",function(){
$.getScript("type.js",function(){
$.getScript("validate.js",function(){
// and so on..
});
});
});
});
PS:用In.js的watch函数是可以避免这种情况产生的。这不在本博文的考虑范围了。
花眼吗?还愿意去对齐代码吗?即便有格式化工具,你还愿意将闭合括号与哪个$.getScript对应吗?当然不愿意。
那么,仿java的导包形式应声而出。
复制代码 代码如下:
Using("User");
Using("Order");
Using("Type");
Using("Validate");
// and so on..
或者你愿意,你可以
复制代码 代码如下:
Using("User","Type","Order","Validate",...);
写法问题 无所谓。当然我推荐使用第一种方法,清晰。
导包之后,所有的用法不需要任何嵌套,正常使用。
复制代码 代码如下:
var u = new User();
var o = new Order();
// and so on..
但是会提出一个问题。假如异步的加载都在Using("XXX")的时候执行,那么
复制代码 代码如下:
Using("User");
Using("Order");
Using("Type");
Using("Validate");
// and so on..
这一段我就需要异步载入4个文件,虽然是异步的,但是未免有些麻烦?而且需要创建4个链接。你愿意合并JS的话,也可以。而且,Using的时候我是不需要使用对象的,这个时候未免太浪费资源了?
至于这个问题,我的解决办法就是学习hibernate,延迟加载,按需加载。
那么怎么做呢?
复制代码 代码如下:
Using("User");
这个时候肯定是不加载,不加载做什么?当然是返回一个mock,也就是模拟对象。给用户先用着,只有当用户真正需要使用这个对象的时候,再去加载所需的js。也就是说
复制代码 代码如下:
Using("User"); // 这句话执行完毕之后会创建一个User对象,当时仅仅是个mock
var u = new User(); // 这个时候用需要的是真实的User对象实例,就在这个时候去动态加载JS文件,并且返回已经实例化的User对象
大家都知道,异步加载是与当前运行的状态不冲突的,也就是说
复制代码 代码如下:
var u = new User();
这句话执行之后,u是一个没有实际意义值的变量,而已。那么,怎么解决这个问题,我暂且想到的办法,只能是采用同步策略了。只有当js加载完毕,再去执行之后的js语句,这个地方有点遗憾,而且同步可能带来的浏览器假死,也是一个比较严重的问题,暂且不顾这些问题,希望以后能有更好的办法解决。
那问题出来了,这么做同步,有什么优势吗?
我不知道有什么优势,起码对比异步加载,应该没有劣势。比如正常的异步加载为
复制代码 代码如下:
$.getScript("user.js",function(){
var u = new User();
});
单单执行这个语句,要执行到function,本质上也是等user.js加载完毕才会执行,那么对比
复制代码 代码如下:
var u = new User();
理论上时间应该相当,因为都是等user.js加载完毕之后才执行的。
起码第二种看起来更像java式的代码,不必理会其他非业务相关的代码。
那么,怎么会知道需要的对象在什么地方,怎么加载进来?我能想到的就是模拟一个配置文件,为什么用配置文件,而不是像In.js用add函数或者其他框架的类似于register的函数,大概我只是想用配置文件,更像java,而且后期的修改起来也会更解耦一些吧。
复制代码 代码如下:
Using.Config = {
"User" : "/js/user" // 可以隐去.js 因为肯定是加载JS文件了
}
整个思路大概就是这个样子,我在其基础上进行了一些约束,比如加入了命名空间
复制代码 代码如下:
var u = new Using.Modules.User();
这样可以减少一些全局变量,而且有需要的话,可以插入一些所有对象可能都具有的共性,减少创建类时的重复编码。
当然,也还是支持不使用命名空间的。
为了解决这个约束的效力,加入了Class.create函数来进行类创建约束。
复制代码 代码如下:
Using.Class.create("User",function(){
}).property({
}).static({
}).namespace(Using.Modules);
这里的大概意思就是
create(类名,构造函数)
property(类的属性)
static(类的静态属性)
namespace(命名空间)
引申到此,为何不加入MVC形式?
后来我发现,要MVC,那么几个类之间的动态维护,或者创建之时就由Using这个类来自动维护,暂时还没想到好的解决办法,所以没有加入其中,只能自己创建类,自己维护了.
通过上面的文字,最后得到一个Using.js
然后在页面里面就只需要引入一个
复制代码 代码如下:
<script type="text/javascript" src="/UploadFiles/2021-04-02/using.js">
这样接下来就可以写
复制代码 代码如下:
Using("jquery");
Using("User");
$("#ID").click(function(){
var user = new User();
user.name = "xx";
user.show();
});
先来一段java代码
复制代码 代码如下:
import Biz.User;
User u = new User();
u.show();
按流程就是导包、实例化、调用。
JS是做不了导包的,或者说代码意义上的导包,一般只是在页面上进行script标签的引入。
那么 先假设需要写成这样
复制代码 代码如下:
Using("User");
var u = new User();
u.show();
那么,在JS里面可以实现吗?
来一句一句的分析,当然,前提是页面并不用script标签载入user.js,不然就没意义了。
第一句
Using("User");
为什么用Using,当然只是我的一个命名想法而已,可以联想一下C#,用的就是using,借来而已。
Using里面写入的当然是我需要的对象User,顾名思义,我当然写成Using("User")了。先不说内里是怎么实现的,起码思路是这样。
因为不能模拟关键字写成 Using User;这种起码我是做不到了。
第二句和第三句
复制代码 代码如下:
var u = new User();
u.show();
很正常,就是很平常的实例化与函数调用,唯一不解的是User对象哪里来的?那么当然是第一句导包的时候导入的。
流程就是这么个流程,那么到底能不能实现,关键就在第一句话。也就是说,到底能不能导包成功,而且该怎么导包。
从script标签吸引灵感,对,异步加载所需要的js文件。
也就是说
复制代码 代码如下:
Using("User");
相当于写了一句
复制代码 代码如下:<script type="text/javascript" src="/UploadFiles/2021-04-02/user.js">
现在这么看下来,这么做有意义吗?就为把script标签写成JS动态引入的?或者,只为少写几个字符?
当然不能,这么做毫无意义!那要怎么做?
先从效率来讲。
如果一个页面需要载入N多js文件的时候,如下
复制代码 代码如下:
<script type="text/javascript" src="/UploadFiles/2021-04-02/jquery.min.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/view.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/register.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/validate.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/user.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/order.js"><script type="text/javascript" src="/UploadFiles/2021-04-02/type.js">
等等等等。
是不是很吓人,那是相当吓人,而且后期维护需要很高的成本,有多少页面,可能就需要修改几个页面。那么,当页面只引入关键的几个js文件,其他文件都采用动态载入的方式呢?
比如我们只需要载入jquery文件,然后调用
复制代码 代码如下:
$.getScript("user.js",function(){});
这样,我们就做到页面文件里面只需要引入
复制代码 代码如下:
<script type="text/javascript" src="/UploadFiles/2021-04-02/jquery.min.js">
即可。
那么这种写法的坏处在哪里?看一段代码
复制代码 代码如下:
$.getScript("user.js",function(){
$.getScript("order.js",function(){
$.getScript("type.js",function(){
$.getScript("validate.js",function(){
// and so on..
});
});
});
});
PS:用In.js的watch函数是可以避免这种情况产生的。这不在本博文的考虑范围了。
花眼吗?还愿意去对齐代码吗?即便有格式化工具,你还愿意将闭合括号与哪个$.getScript对应吗?当然不愿意。
那么,仿java的导包形式应声而出。
复制代码 代码如下:
Using("User");
Using("Order");
Using("Type");
Using("Validate");
// and so on..
或者你愿意,你可以
复制代码 代码如下:
Using("User","Type","Order","Validate",...);
写法问题 无所谓。当然我推荐使用第一种方法,清晰。
导包之后,所有的用法不需要任何嵌套,正常使用。
复制代码 代码如下:
var u = new User();
var o = new Order();
// and so on..
但是会提出一个问题。假如异步的加载都在Using("XXX")的时候执行,那么
复制代码 代码如下:
Using("User");
Using("Order");
Using("Type");
Using("Validate");
// and so on..
这一段我就需要异步载入4个文件,虽然是异步的,但是未免有些麻烦?而且需要创建4个链接。你愿意合并JS的话,也可以。而且,Using的时候我是不需要使用对象的,这个时候未免太浪费资源了?
至于这个问题,我的解决办法就是学习hibernate,延迟加载,按需加载。
那么怎么做呢?
复制代码 代码如下:
Using("User");
这个时候肯定是不加载,不加载做什么?当然是返回一个mock,也就是模拟对象。给用户先用着,只有当用户真正需要使用这个对象的时候,再去加载所需的js。也就是说
复制代码 代码如下:
Using("User"); // 这句话执行完毕之后会创建一个User对象,当时仅仅是个mock
var u = new User(); // 这个时候用需要的是真实的User对象实例,就在这个时候去动态加载JS文件,并且返回已经实例化的User对象
大家都知道,异步加载是与当前运行的状态不冲突的,也就是说
复制代码 代码如下:
var u = new User();
这句话执行之后,u是一个没有实际意义值的变量,而已。那么,怎么解决这个问题,我暂且想到的办法,只能是采用同步策略了。只有当js加载完毕,再去执行之后的js语句,这个地方有点遗憾,而且同步可能带来的浏览器假死,也是一个比较严重的问题,暂且不顾这些问题,希望以后能有更好的办法解决。
那问题出来了,这么做同步,有什么优势吗?
我不知道有什么优势,起码对比异步加载,应该没有劣势。比如正常的异步加载为
复制代码 代码如下:
$.getScript("user.js",function(){
var u = new User();
});
单单执行这个语句,要执行到function,本质上也是等user.js加载完毕才会执行,那么对比
复制代码 代码如下:
var u = new User();
理论上时间应该相当,因为都是等user.js加载完毕之后才执行的。
起码第二种看起来更像java式的代码,不必理会其他非业务相关的代码。
那么,怎么会知道需要的对象在什么地方,怎么加载进来?我能想到的就是模拟一个配置文件,为什么用配置文件,而不是像In.js用add函数或者其他框架的类似于register的函数,大概我只是想用配置文件,更像java,而且后期的修改起来也会更解耦一些吧。
复制代码 代码如下:
Using.Config = {
"User" : "/js/user" // 可以隐去.js 因为肯定是加载JS文件了
}
整个思路大概就是这个样子,我在其基础上进行了一些约束,比如加入了命名空间
复制代码 代码如下:
var u = new Using.Modules.User();
这样可以减少一些全局变量,而且有需要的话,可以插入一些所有对象可能都具有的共性,减少创建类时的重复编码。
当然,也还是支持不使用命名空间的。
为了解决这个约束的效力,加入了Class.create函数来进行类创建约束。
复制代码 代码如下:
Using.Class.create("User",function(){
}).property({
}).static({
}).namespace(Using.Modules);
这里的大概意思就是
create(类名,构造函数)
property(类的属性)
static(类的静态属性)
namespace(命名空间)
引申到此,为何不加入MVC形式?
后来我发现,要MVC,那么几个类之间的动态维护,或者创建之时就由Using这个类来自动维护,暂时还没想到好的解决办法,所以没有加入其中,只能自己创建类,自己维护了.
通过上面的文字,最后得到一个Using.js
然后在页面里面就只需要引入一个
复制代码 代码如下:
<script type="text/javascript" src="/UploadFiles/2021-04-02/using.js">
这样接下来就可以写
复制代码 代码如下:
Using("jquery");
Using("User");
$("#ID").click(function(){
var user = new User();
user.name = "xx";
user.show();
});
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
2025年01月26日
2025年01月26日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]