自己编写jQuery动态引入js文件插件 (jquery.import.dynamic.script)
这个插件主要是结合jquery或者xhr异步请求来使用的,它可以把已经引入过的js文件记录在浏览器内存中,当下次再引入相同的文件就忽略该文件的引入。
当你用$.load("dir/my-page.jsp"); 或xhr.request("server/to-my-page");等异步请求加载html页面的时候,在页面中导入js文件用本插件进行引入的话,
那么其他请求的页面中也导入了和前面页面相当的js文件的情况下,那这些js文件就不需要重新引入。插件会自动忽略之前已经引入过的文件,来节约开销加快速度。
此插件不支持浏览器刷新保存数据,那需要利用cookie来保存引入数据记录。这里只时候异步加载js文件的方式。
使用本插件必须先引入jquery,后再引入动态导入插件js文件。在不刷新页面的情况下,本插件导入的javascript只需用导入一次,后面都会使用上一次导入的缓存文件
下面简单说下插件用法,使用规则方法:
1、导入一个文件
// 导入一个文件
$.imports("${pageContext.request.contextPath }/statics/js/jquery.json/jquery.json.js");
//src=导入文件;delay=延迟200毫秒导入;参数once=表示每次都导入,忽略上次导入(大部分情况不需要设置)
$.imports({ src: "${pageContext.request.contextPath }/statics/js/jquery.json/jquery.json.js", delay: 200, once: false });
2、导入多个文件
// 导入多个文件
$.imports("dir/jquery.json.js", "dir/jquery.json2.js", ".....");
$.imports(["dir/jquery.json.js", "dir/jquery.json2.js", "....."]);导入多个js文件,额外加些配置
$.imports([
{ src: "${pageContext.request.contextPath }/statics/js/jquery.json/jquery.json.js", delay: 200, once: false },
{ src: "${pageContext.request.contextPath }/statics/js/jquery.json/jquery.json.js", delay: 200 }
]); $.imports(
"${ctxPath }/statics/js/jquery.raty.min.js",
{ src: "${ctxPath }/statics/js/student/appraise.js", once: false }
);
3、导入js文件完成后,执行回调函数
//支持回调,有回调函数的将使用同步导入。就是前面的javascript都会按顺序导入
$.imports("dir/jquery.json.js", "dir/jquery.json2.js", ".....", function () {
//call back
});
4、全部完整配置参数列表
//完整参数
$.imports({
// 根路径
rootPath: ctxPath,
scripts: [ {
src: "js/1.js", // js路径
delay: 10, // 延迟加载时间
once: true // 是否导入一次,默认ture
}, {
path: "js/2.js", // js路径
once: false // 是否导入一次,默认ture
} ],
// 全局延迟
delay: 100,
// 回调函数,如果需要的话。使用回调函数将进入同步模式
callback: function () {
//导入完成执行
},
// 是否开启缓存,默认开启
cache: true,
// 开启日志模式
debug: false
});上面的同步模式是指js文件的引入顺序就是加载的顺序,因为有时候后面引入的js依赖前面的就是文件。如果不同步会有找不到变量、方法的问题。当然同步会影响性能,那没得说的。
庐山真面目,插件源码在此:
/***
* jquery.import.dynamic.script-debug.js plugin
* v1.1
* @createDate -- 2015-08-04
* @author hoojo
* @email hoojo_@126.com
* @requires jQuery v1.8.3 or later
* Copyright (c) 2015 M. hoojo
* Dual licensed under the MIT and GPL licenses:
* http://blog.csdn.net/IBM_hoojo
**/
;(function ($) { var defaultOptions = {
// 根路径
rootPath: (function () {
var path = ctxPath || window.location.host + "/eduyun/";
return path;
})(),
scripts: [ {
path: "", // js路径
src: "", // js路径
delay: 0, // 延迟加载时间
once: true // 是否导入一次,默认ture
} ],
// 导入过的历史记录值栈
importStack: {},
// 全局延迟
delay: 0,
// 回调函数,如果需要的话。使用回调函数将进入同步模式
callback: null,
// 是否开启缓存,默认开启
cache: false,
// 开启日志模式
debug: false,
log: function (msg) {
if (defaultOptions.debug) {
console.log(msg);
}
}
}; var _options = defaultOptions;
_options.scripts = new Array(); // 动态导入JavaScript核心代码
var importScript = function (settings, scripts, call) { var item = scripts.shift(); if ($.type(item) === "string") {
item = { path: item, once: true };
} else if ($.type(item) === "object") {
} else {
throw new Error("unknow params type!");
} var script = item.path || item.src;
var delay = item.delay || _options.delay;
var once = item.once === undefined ? true : item.once; if (script) {
if (!~script.indexOf(_options.rootPath) && !~script.indexOf("http://")) {
script = _options.rootPath + script;
} _options.log("================= import stack value ===================");
_options.log(_options.importStack); if (!_options.importStack[script] || !once) { window.setTimeout(function () {
if (!$("scripts").get(0)) {
$("body:first").append("<scripts/>");
} if (call) {
_options.log("synchronize import script :" + script + ", delay import script: " + delay); $.ajax({
url: script,
dataType: "script",
cache: settings.cache || _options.cache,
async: true,
success: function () {
$("scripts").append('<import src="' + script + '"/>');
_options.importStack[script] = true;
if (scripts.length == 0) {
return call();
} else {
importScript(settings, scripts, call);
}
}
});
} else {
_options.log("asynchronous import script :" + script + ", delay import script: " + delay);
//$("scripts").append('<script src="' + script + '" type="text/javascript" charset="utf-8"></script> <import src="' + script + '"/>');
$.ajax({
url: script,
dataType: "script",
cache: settings.cache || _options.cache,
async: true,
success: function () {
$("scripts").append('<import src="' + script + '"/>');
_options.importStack[script] = true;
}
}); if (scripts.length == 0) {
return;
} else {
importScript(settings, scripts, null);
}
} }, delay);
} else {
_options.log("exists script :" + script);
if (scripts.length == 0) {
if (call) return call();
} else {
importScript(settings, scripts, call);
}
}
}
}; var mergeScripts = function (args) {
var scripts = [];
for (var i = 0; i < args.length; i++) {
if ($.type(args[i]) === "array") {
scripts = scripts.concat(args[i]);
} else {
scripts.push(args[i]);
}
} return scripts;
}; // 提供jquery 插件方法
$.extend({
imports: function (opts) { _options.log("=================== opts ===================");
_options.log(opts);
_options.log("=================== _options ===================");
_options.log(_options); var settings = {};
if (arguments.length <= 1) {
var _type = $.type(opts);
if (_type === "string") {
$.extend(settings, _options);
settings.scripts.push(opts);
} else if (_type === "object") {
if (opts.scripts) {
$.extend(settings, _options, opts);
} else {
$.extend(settings, _options);
settings.scripts.push(opts);
}
} else if (_type === "array") {
$.extend(settings, _options, { scripts: opts });
} else {
throw new Error("unknow data type!");
}
} else {
var args = Array.prototype.slice.call(arguments);
if ($.type(args[args.length - 1]) === "function") {
var call = args.pop();
var scripts = mergeScripts(args);
$.extend(settings, _options, { scripts: scripts });
settings.callback = call;
} else {
var scripts = mergeScripts(args);
$.extend(settings, _options, { scripts: scripts });
}
} _options.log("=================== settings ===================");
_options.log(settings);
_options.log("=================== _options ===================");
_options.log(_options); importScript(settings, settings.scripts, settings.callback);
}
}); })(jQuery);
自己编写jQuery动态引入js文件插件 (jquery.import.dynamic.script)的更多相关文章
- 1.在html中引入js文件和Jquery框架
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 使用Jquery promise 动态引入js文件
动态加载一个js得方式很多,如下方式: /** *一般方式加载 */ function normalLoadScript(url) { var node = document.createElemen ...
- 动态引入Js文件
var src = "/Scripts/Test.js"; $("<script type = 'text/javascript' src='" + sr ...
- jsp引入js文件
转自:http://blog.csdn.net/ppzhangj/article/details/7859628 1)引入的js文件出错, 检查方法:将Js的内容写在当前的页面的<script& ...
- 项目一:第四天 1、快递员的条件分页查询-noSession,条件查询 2、快递员删除(逻辑删除) 3、基于Apache POI实现批量导入区域数据 a)Jquery OCUpload上传文件插件使用 b)Apache POI读取excel文件数据
1. 快递员的条件分页查询-noSession,条件查询 2. 快递员删除(逻辑删除) 3. 基于Apache POI实现批量导入区域数据 a) Jquery OCUpload上传文件插件使用 b) ...
- vue脚手架使用swiper /引入js文件/引入css文件
1.安装vue-cli 参考地址:https://github.com/vuejs/vue-cli 如果不使用严格语法需要在后三项打no:(加了挺头疼的,老是报错,但是对自己的代码规范性也是有很大的帮 ...
- jQuery动态网格瀑布流插件Masonry
Masonry是一款非常强大的jQuery动态网格布局插件,可以帮助开发人员快速开发瀑布流界面效果.和CSS中float的效果不太一样的地方在于,float先水平排列,然后再垂直排列,使用Masonr ...
- 关于 ajax 动态返回数据 css 以及 js 失效问题(动态引入JS)
ajax 毕竟是异步的 所以动态加载出来的数据 难免遇到 css 或者 js 失效的问题,所以要动态加载 css ji等文件了 1.公共方法 load //动态加载 js /css function ...
- jquery.nicescroll.min.js滚动条插件的用法
1.jquery.nicescroll.min.js源码 /* jquery.nicescroll 3.6.8 InuYaksa*2015 MIT http://nicescroll.areaaper ...
随机推荐
- java设计模式之职责链模式
责任链模式 设计模式很多时候都是看见名字都知道意思,责任链,见名知义为请求创建一系列处理对象. 此模式基于请求的类型将请求的发送方和接收方分离.通常每个接收器包含对另一个接收器的引用.如果一个对象不能 ...
- Nagios邮件报警
p.MsoNormal,li.MsoNormal,div.MsoNormal { margin: 0cm; margin-bottom: .0001pt; line-height: 150%; fon ...
- day001-html知识点总结(二)不常见但很重要的元素汇总
一..vertical-align:设置垂直对齐方式,主要用于: 1.单元格内容的垂直对齐 2.对于行内块级元素,如<img>,设置行内元素的基线相对于该行内块级元素的所在行的基线对齐,例 ...
- android studio 2.3 下载地址
android studio下载: Windows+SDK:(1.8GB)| Windows(428 MB) | Linux idea win.exe win.zip 序号 名称 中文 ...
- oracle导入时提示IMP-00010:不是有效的导出文件,头部验证失败
oracle导入时提示IMP-00010:不是有效的导出文件,头部验证失败: 原因分析:导出的oracle的版本与导入的oracle数据库的版本不一致: 可直接将dmp文件用notepad++打开修改 ...
- 设计模式(1)单例模式(Singleton)
设计模式(0)简单工厂模式 源码地址 0 单例模式简介 0.0 单例模式定义 单例模式是GOF二十三中经典设计模式的简单常用的一种设计模式,单例模式的基本结构需满足以下要求. 单例模式的核心结构只有一 ...
- java设计模式--基础思想总结--父类引用操作对象
看设计模式的相关书籍也有一段时间了,一开始其实是抱着作为java三大框架的基础知识储备来学习的,不过到后来,才发现,在设计模式的一些准则装饰下,java的面向对象威力才真正地体现出来,后面的将会陆续地 ...
- AspNetCore - MVC实战系列(一)
本章开篇先简单介绍下最近两周自己利用业余时间做的一个图片收集网站,当然这个是靠用户自己上传来收集不是去抓某些个网站的图片,那样没意义,这里我取名为“爱留图”:该网站的简单介绍大家可以参考下上篇的内容爱 ...
- Linq 查询与普通查询的区别
普通:select * --1 from User(表名) as u --2 where u.Name like '%s%' --3 Linq : from User(表名) as u --1 whe ...
- 篇3 安卓app自动化测试-搞定界面元素
篇3 安卓app自动化测试-搞定界面元素 --lamecho辣么丑 1.1概要 大家好! 我是lamecho(辣么丑),今天是<安卓app自动化测试>的第三 ...