js的动态加载、缓存、更新以及复用(四)
本来想一气呵成,把加载的过程都写了,但是卡着呢,所以只好在分成两份了。
1、页面里使用<script>来加载 boot.js 。
2、然后在boot.js里面动态加载 bootLoad.js。以时间作为标识 var dateVer = date.getYear() + '_' + date.getMonth() + '_' + date.getDate() + '_' + date.getHours(); 这样可以保证一小时内肯定会被更新。同时也避免了每次都去更新。
3、boot.js里面根据情况调用 bootLoad.js里提供的函数。目的是为了把有可能变化的都放在 bootLoad.js 里面以便于能够控制更新。
4、如果是top页面,则调用bootLoad.js里的Nature.Top.topLoad(loads, kind); ;如果是子页面则调用 top.Nature.Top.sonLoad(loads, kind,window); 进行后续处理。
5、topLoad(),首先获取最新的版本号,然后加载Nature.LoadJs.js,实现其他js的文件的加载。如果js文件有更新,那么获取的最新版本号就会发生变化,这样就可以实现js文件的及时更新了。
6、sonLoad()则会加载Nature.Adapter.js,实现复用,就是让子页面可以调用top页面里的js。
简单的说呢就是这样。详细说的话还有很多细节。目前boot.js基本稳定。bootLoad.js也差不多了。Nature.LoadJs.js还需要在改一改。以前写的太乱了。

boot.js的代码。
/* 加载js脚本的一种解决方法。 by 金色海洋 2013-7-11 */ //1毫秒后开始加载 js文件
window.setTimeout(function() { //判断有无配置信息————没有的话,加载且缓存
//判断有无js文件版本号——没有的话,加载且缓存
//加载Nature.LoadJs.js,开始加载其他js
//判断页面是否有jsReady,如果有则开始调用 //var bootScript = $("script").frist(); //获取标签
//var pageKind = bootScript.attr("pageKind"); //获取标签里的属性 var kind = (typeof pageKind == "string") ? pageKind : "index"; /*默认的网页类型*/ var loads = new loadscript(document); //把本页面作为参数传递进去。因为涉及到复用,所以要new一下。 if (typeof top.Nature == "undefined") {
//没有配置信息,加载。用y_MM_dd_HH作为版本标志,一个小时更新一次。因为可以缓存配置信息,所以不是每次都让浏览器加载
var date = new Date();
var dateVer = date.getYear() + '_' + date.getMonth() + '_' + date.getDate() + '_' + date.getHours(); //加载第一个主程序。分开的目的是为了可以控制更新。
loads.js('/bootLoad.js?rnd=' + dateVer, function () {
Nature.Top.topLoad(loads, kind); //走top页面的流程
});
} else {
//走子页面的流程,把子页面(window)作为参数传递进去,以便于和top页面区分。因为函数是放在top页面里的。
//sonLoad不在子页面里,而是存在于top里,所以要 top.sonLoad
top.Nature.Top.sonLoad(loads, kind, window);
} /*实现动态加载js的函数,来自于互联网,做了一点修改,可以兼容IE10。IE11没测试。
* 写在函数里面,不污染window了。
* 增加加载css的函数
* 原来是静态的,现在改成需要实例化的。
*/
function loadscript(doc) {
this.js = function(url, callback) {
var s = doc.createElement('script');
s.type = "text/javascript";
s.src = url;
s.expires = 1;
load(s, callback);
};
this.css = function (url, callback) {
var l = doc.createElement('link');
l.type = "text/css";
l.rel = "stylesheet";
l.media = "screen";
l.href = url;
//doc.getElementsByTagName('head')[0].appendChild(l);
load(l, callback);
}; function load(s, callback) {
switch (doc.documentMode) {
case 9:
case 10:
case 11:
s.onerror = s.onload = loaded;
break;
default:
s.onreadystatechange = ready;
s.onerror = s.onload = loaded;
break;
}
doc.getElementsByTagName('head')[0].appendChild(s); function ready() { /*IE7.0/IE10.0*/
if (s.readyState == 'loaded' || s.readyState == 'complete') {
if (typeof callback == "function") callback();
}
} function loaded() { /*chrome/IE10.0*/
if (typeof callback == "function") callback();
}
}
} }, 1);
bootLoad.js
/*
加载js脚本的一种解决方法。
by 金色海洋 2013-7-11
2014-06-07 移植
*/
var Nature = {};/* 定义 一个很大的对象 */
Nature.Top = {};/* 加载js用的命名空间 */
/*数据库的设置*/
Nature.WebConfig = {
isShowPeiZhi: true, //页面里是否显示“配置”,程序员编辑时设置为 true。上线后设置为 false
WebappID: 7,
dbid_236Write: "2,4", //统一管理数据连接标识
dbid_236WriteJM: "2,14", //统一管理数据连接标识
dbid_236SysLog: "2,6", //wcf日志数据库
dbid_Loan: "2,13", //快易贷测试数据库
//dbid_Loan: "2,12" //快易贷正式数据库
};
/*ajax的设置*/
Nature.AjaxConfig = {
UrlResource: "http://LCNatureResource.517.cn", /*增删改查服务的网址*/
Urljs: "http://LCNatureResource.517.cn", /*js文件的网址*/
Urlsso: "http://LCNatureService.517.cn", /*单点登录的网址*/
Urlcss: "http://mango-js.517.cn", /*css文件的网址*/
ajaxDataType: "json" /*跨域的时候用jsonp,不用跨域的话用json,cors跨域的话也是json*/
};
Nature.AjaxConfig.UrljsVer = Nature.AjaxConfig.Urljs + "/Scripts/NatureAjax/ver.js", /*存放js文件版本号的网址*/
Nature.AjaxConfig.UrlLoadJs = Nature.AjaxConfig.Urljs + "/Scripts/NatureAjax/Nature.LoadJs.js", /*加载其他js文件的网址*/
Nature.AjaxConfig.UrlAdapter = Nature.AjaxConfig.Urljs + "/Scripts/NatureAjax/Nature.Adapter.js", /*适配的网址*/
/* 复用父页面里的js文件的时候使用。是否使用自己页的js。true:本页加载js文件。false:使用父页的js文件。*/
//Nature.isSelfJs = false;
Nature.Top.LoadCss = function(loadCss) {
var cssUrl = Nature.AjaxConfig.Urlcss;
loadCss.css(cssUrl + '/websiteStyle/mangoGlobal.css');
loadCss.css(cssUrl + '/misStyle/misUICss/misStyle/mis-style-p.css');
loadCss.css(cssUrl + '/misStyle/misUICss/misStyle/MisStyle_v2.css');
loadCss.css(cssUrl + '/misStyle/debugCss/css.css');
loadCss.css(Nature.AjaxConfig.UrlResource + '/Scripts/css/css2.css');
};
//外壳页的加载
Nature.Top.topLoad = function(loadscript, kind) {
//判断有无配置信息————没有的话,加载且缓存
//判断有无js文件版本号——没有的话,加载且缓存
//加载Nature.LoadJs.js,开始加载其他js
//判断页面是否有jsReady,如果有则开始调用
/*加载css文件*/
Nature.Top.LoadCss(loadscript);
//加载js版本号
var checkCount = 0;
if (typeof Nature.jsVer == "undefined") {
/*加载js文件的版本号,用于更新浏览器的js缓存文件。使用随机数作为参数,保证版本号是最新的。
* 用随机数保证最新,因为可以缓存,所以不是每次访问都会去加载
*/
loadscript.js(top.Nature.AjaxConfig.UrljsVer + '?rnd=' + Math.random(), function() { //
loadOtherJs();
});
} else {
loadOtherJs();
}
//加载Nature.LoadJs
function loadOtherJs() {
/*得到了版本号,加载LoadJs.js,该文件加载其他需要的js文件*/
loadscript.js(top.Nature.AjaxConfig.UrlLoadJs + Nature.jsVer, function () {
var loadJs = new Nature.loadFile(document);
loadJs.startLoadJs(kind, checkReady);
});
}
/*检查页面是否有jsReady */
function checkReady() {
if (typeof jsReady == "function") {
//执行页面里的函数
jsReady();
} else {
//检查次数,尝试十次,超了就不玩了,避免死循环。*/
if (checkCount < 10) {
checkCount++;
setTimeout(checkReady, 50);
}
}
}
};
//子页的加载
Nature.Top.sonLoad = function(loadscript, kind, win) {
var checkCount = 0;
top.Nature.Top.LoadCss(loadscript);
win.Nature = {};
loadscript.js(top.Nature.AjaxConfig.UrlAdapter + top.Nature.jsVer, function () {
win.Nature.Adapter(win);
checkReady();
});
/*检查页面是否有jsReady */
function checkReady() {
if (typeof win.jsReady == "function") {
//执行页面里的函数
win.jsReady();
} else {
//检查次数,尝试十次,超了就不玩了,避免死循环。*/
if (checkCount < 10) {
checkCount++;
setTimeout(checkReady, 50);
}
}
}
};
下次就是 Nature.LoadJs.js 的介绍了。
js的动态加载、缓存、更新以及复用(四)的更多相关文章
- js插件动态加载js、css解决方案
最近因为工作需要做了一个js自动导入的插件,一开始很天真的以为动态创建个script添加到head中就ok了,试了之后才发现了问题,就是如果同时引入了多个js文件,而且后一个文件中用到了前一个文件中的 ...
- js实现动态加载脚本的方法实例汇总
本文实例讲述了js实现动态加载脚本的方法.分享给大家供大家参考,具体如下: 最近公司的前端地图产品需要做一下模块划分,希望用户用到哪一块的功能再加载哪一块的模块,这样可以提高用户体验. 所以到处查 ...
- js的动态加载、缓存、更新以及复用(一)
使用范围: OA.MIS.ERP等信息管理类的项目,暂时不考虑网站. 遇到的问题: 完成一个项目,往往需要引用很多js文件,比如jQuery.js.easyUI等.还有自己写的一些列js文件,那么这些 ...
- js的动态加载、缓存、更新以及复用
使用范围: OA.MIS.ERP等信息管理类的项目,暂时不考虑网站. 遇到的问题: 完成一个项目,往往需要引用很多js文件,比如jQuery.js.easyUI等.还有自己写的一些列js文件,那么这些 ...
- js的动态加载、缓存、更新以及复用(三)
总体思路 1. 建立一个js服务,该服务实现通用js文件的加载.依赖.缓存.更新以及复用. 2. 各个项目如果使用通用js,可(bi)以(xu)使用js服务实现加载. 3. Js服务只提供通用的 ...
- js的动态加载、缓存、更新以及复用(二)
上一篇发出来后得到了很多回复,在此首先感谢大家的热情捧场!有的推荐第三方框架,比如 In.js.requrieJS.sea.js.lab.js等.这个开阔了眼界,以前只知道sea.js,省去了自己搜索 ...
- Ext JS 如何动态加载JavaScript创建窗体
JavaScript不需要编译即可运行,这让JavaScript构建的应用程序可以变得很灵活.我们可以根据需要动态从服务器加载JavaScript脚本来创建和控制UI来与用户交互.下面结合Ext JS ...
- js怎么动态加载js文件(JavaScript性能优化篇)
下面介绍一种JS代码优化的一个小技巧,通过动态加载引入js外部文件来提高网页加载速度 [基本优化] 将所有需要的<script>标签都放在</body>之前,确保脚本执行之前完 ...
- 篇一:js中动态加载---append
之前是一行代码,不能动态加载,新的需求要动态加载,使用append $('#Order_information').append(' <div class="single_produc ...
随机推荐
- 在configure distribution时遇到错误,不能打开sql agent
今天在配置Distribution时,遇到一个错误,不能打开sql agent,详细错误信息如下: SQL Server blocked access to procedure 'dbo.sp_set ...
- SQL Server中的版本号
在SQL Server中,通常版本号的命名是大版本.小版本.累积更新这种形式,比如说9.X.XXX就是SQL Server 2005.下面我将把SQL Server中版本号对应的版本列出来,以 ...
- toString()方法
前面的话 本文将介绍toString()方法,toString()方法返回反映这个对象的字符串 [1]undefined和null没有toString()方法 undefined.toString() ...
- JAVA设计模式《四》
经过前几篇的介绍相信大家对JAVA的设计模式一定有所解了,本篇我们再一起学习一下适配器模式.代理模式和工厂模式. 适配器模式使用的场景非常多,例如现实生活中,我们的笔记本电脑的充电线大部分都是三向插头 ...
- Web 前端开发人员和设计师必读文章推荐【系列二十八】
<Web 前端开发精华文章推荐>2014年第7期(总第28期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML5 ...
- ASP.NET 网站从Sever2003迁移到Sever 2008部署后不能访问
最近公司运维迁移网站遇到部署后始终不能访问,一直提示无法访问请求的页面,但是请求页面正常,程序没问题,在本地电脑运行正常,运维找了好久没找到原因. 后来问我,我也找了好久,最后终于解决了. 解决方法是 ...
- Java线程面试题 Top 50 (转载)
转载自:http://www.cnblogs.com/dolphin0520/p/3958019.html 原文链接:http://www.importnew.com/12773.html 本文由 ...
- Math.ceil(a/b)结果出错--原因是a和b不是double
脑袋短路.连续测试几次发现Math.ceil(188/20)==9; 忍无可忍,突然发现是int问题,顺着表达式走一遍,188/20==9,然后再向上取整.脑袋僵化了.看来一直做简单的不动脑筋的工作, ...
- .NET Core扩展IServiceCollection自动注册服务
前言 在ASP.NET Core中使用依赖注入中使用很简单,只需在Startup类的ConfigureServices()方法中,通过IServiceCollection接口进行注入即可,其它的无需关 ...
- winform中ComboBox利用AutoComplete属性实现模糊查询(有缺陷)
上一篇文章是用ComboBox里面的原生事件实现模糊查询,操作比较灵活一些,但是收到评论说,利用AutoComplete属性就可以实现模糊查询,但是据本人所了解,AutoComplete虽然能够方便的 ...