也说JS脚本加载控制
问题背景
前端采用的 iframe + html 做后台管理系统。现在js、jquery插件非常多,每次页面都是引用就类似这样:
<script src="../Scripts/jquery-1.7.1.js"></script>
<script src="../Scripts/uploadify/jquery.uploadify.js"></script>
<script src="../Scripts/uploadify/swfobject.js"></script>
<link href="../Scripts/uploadify/uploadify.css" rel="stylesheet" />
有时候需要更新其中一个组件,为了避免客户端浏览器手动刷新,一般的做法是增加版本号,比如 xxx.js?v=1111。
或者说,需要删掉某个组件,引用某个组件。
在这2种情况下,都需要针对每个页面,增加 script 引用。每次新建一个html,就要把之前的页面的 script 引用都复制过来,有木有?
解决办法
现在有Require.js , sea.js ,labjs 等等各种高大上的框架。
以上框架中,楼主仅试过用lab.js解决这种问题,它可以很好的控制脚本的异步加载,以及脚本的依赖,然后可以在脚本加载完毕后,做初始化的操作。当时仅仅是做了一个Demo,一直过了很长时间,也没有使用,原因无它,如果希望能控制脚本的动态加载时,又希望像以前一样直接在页面上引用script,换句话来说,楼主要的不是重写脚本引用方式,而是在原有基础上稍作改善。
关键方法很简单,使用了 document.writeIn('...') 来加载。这种加载方式,是同步加载,就是它了。
具体思路则是,定义一个数组存放脚本以及css路径,建议使用绝对路径,这样不会因为页面所在的位置而导致脚本加载不上。
然后做了一点点小改进,同步加载js,异步加载css。同时支持设置版本号,这样可以轻松控制客户端的自动更新。大致实现代码如下:
在实际应用过程中,这个js脚本,是会经常发生变更,所以必须再通过 document.writeIn 加载这个脚本。首先可以以如下形式写在页面中
<script>
document.writeIn('...');
</script>
这样略微不方便啦。于是楼主又写了一个脚本,仅仅只有如上一行代码,就是用来控制加载前面定义通用的脚本组件。这个只有一行代码的脚本,是万年不变的,所有页面直接引用即可,由它来控制后面的脚本变化。
测试
上面说,脚本加载的形式是同步的,为了证明这一点,楼主不得不写一点简单的例子。看看下面的html代码:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
</head>
<body>
<input type="text" id="uid" value="111" />
</body>
</html>
<script src="Scripts/com/boot.js"></script>
<script>
alert($("#uid").val());
</script>
而boot.js就是引导脚本,就是之前提到的一行代码:
/*引导加载所有的js文件*/document.writeln("<script src='/Scripts/com/bootallscript.js?v=" + Math.random() + "'><\/script>");
bootallscript.js就是最核心的了,复杂加载所有的js和css。
(function () {
var base = '/Scripts/';
var loader = {
base: '/Scripts/',
ver: 1,
content: [ //定义需要加载的脚本
'jquery-1.7.1.min.js'
],
loadcss: function (cssUrl) {
var link = document.createElement("link");
link.rel = "stylesheet";
link.type = "text/css";
link.href = cssUrl;
document.getElementsByTagName("head")[0].appendChild(link);
},
run: function () {
for (var i in loader.content) {
var c = loader.content[i];
if (c.length <= 2) continue;
var p = loader.base + c + "?v=" + loader.ver;;
var type = c.substr(c.length - 2, c.length);
if (type === 'js') { //同步加载js文件
document.writeln("<script src='" + p + "' ><\/script>");
} else { //异步加载css文件
loader.loadcss(p);
}
}
}
};
//加载js脚本
loader.run();
})();
运行后会发现,页面在加载完成后,使用jQuery获取到了控件的值。这种方式和原来的直接脚本引用,差别不大吧。
说到这里,我们新建页面后,只需要引用 boot.js就能加载上所有的组件,而页面逻辑相关的js,也可以直接引用在boot.js下方,没有改变原来的脚本引用习惯,又能极大的节省了代码,完善对脚本的控制,这就是楼主想要的效果了。
写在最后,当然mvc对类似的问题有了解决方案,这里不探讨,因为讨论的是 前端 iframe+html 无 C# 。
也说JS脚本加载控制的更多相关文章
- CSS样式表、JS脚本加载顺序与SpringMVC在URL路径中传参数与SpringMVC 拦截器
CSS样式表和JS脚本加载顺序 Css样式表文件要在<head>中先加载,这样网页显示时可以第一次就渲染出正确的布局和样式,网页就不会闪烁,或跳变 JS脚本尽可能放在<body> ...
- JS脚本加载与执行对性能的影响
高性能JavaScript-JS脚本加载与执行对性能的影响 在web产品优化准则中,很重要的一条是针对js脚本的加载和执行方式的优化.本篇文章简单描述一下其中的优化准则. 1. 脚本加载优化 1.1 ...
- 外部引入的js 判断js脚本加载是否完成,完成后执行 相应的动作(以引入百度地图js为例)
可以使用JQuery的 $.getScript(url,function(){});方法 $.getScript("http://api.map.baidu.com/getscript?v= ...
- requere.js优化js脚本加载方案,使用篇。
require.config({ paths: { "jquery": "jquery-3.2.1", 'index':"index" }} ...
- js文件加载太慢,JavaScript文件加载加速
原文出自:https://blog.csdn.net/seesun2012 js脚本加载太慢,JavaScript脚本加载加速(亲测有效) 测试背景: JS文件大小:6.1kB 传统形式加载js文件: ...
- JS 动态加载脚本 执行回调_转
关于在javascript里面加载其它的js文件的问题可能很多人都遇到过,但很多朋友可能并不知道怎么判断我们要加载的js文件是否加载完成,如果没有加载完成我们就调用文件里面的函数是不会成功的.本文讲解 ...
- js动态加载脚本
最近公司的前端地图产品需要做一下模块划分,希望用户用到哪一块的功能再加载哪一块的模块,这样可以提高用户体验. 所以到处查资料研究js动态脚本的加载,不过真让人伤心啊!,网上几乎都是同一篇文章,4种方法 ...
- JS 动态加载脚本的4种方法
有时候我们需要动态的加入适合的js,因为有时候不需要将所有的js都加载进来,以来提高效率,但这种方法比较适合单个js文件比较大的情况 如果js文件都比较小,还是一个js好,这样可以减少连接数.下面是4 ...
- JS 动态加载脚本 执行回调
JS 动态加载脚本 执行回调 关于在javascript里面加载其它的js文件的问题可能很多人都遇到过,但很多朋友可能并不知道怎么判断我们要加载的js文件是否加载完成,如果没有加载完成我们就调用文件 ...
随机推荐
- jquery框架一点小心得
下面的小事例 主要实现了 一和按ID查找,并获取元素的 value 或 标签内容和一个去字符串空格的小功能能 假设元素id=“myid”: 获取标签内容$("myid").html ...
- 「学习记录」《数值分析》第三章计算实习题(Python语言)
第三题暂缺,之后补充. import matplotlib.pyplot as plt import numpy as np import scipy.optimize as so import sy ...
- 使用JDK自带的keytool工具生成证书
一.keytool 简介 keytool 是java用于管理密钥和证书的工具,它使用户能够管理自己的公钥/私钥对及相关证书,用于(通过数字签名)自我认证(用户向别的用户/服务认证自己)或数据完整性以及 ...
- Qt 隐藏标题栏可移动升级版
在最出的时候,在Qt程序隐藏标题栏的情况下,实现界面可拖拽移动,是鼠标在在程序界面的任意位置都可以,现在这个版本是需要鼠标在程序界面的特定位置开可以 上代码 static QPoint last(0, ...
- 安装VMware的一般步骤(安装过程总结)
(安装的是vmwareworkstation11以上) 0.遇到问题为没有权限打开服务“VMAuthdService”时,需要去管理->服务中打开对应的Windows Management In ...
- 爬虫:Scrapy17 - Common Practices
在脚本中运行 Scrapy 除了常用的 scrapy crawl 来启动 Scrapy,也可以使用 API 在脚本中启动 Scrapy. 需要注意的是,Scrapy 是在 Twisted 异步网络库上 ...
- jqprint导入jqgrid表格时,内容溢出的原因以及解决方法
jqprint在导入表格的时候,会将原表格的样式全部拉过来,所以说原表格(如jqgrid的表格)的内容在有滚动条的时候,必须得将宽度设置为100%(等百分比的宽度),不能设置成固定宽度,不然表格内容会 ...
- C++STL——概述
一.相关介绍 STL 标准模板库 在编写代码的过程中有一些程序经常会被用到,而且需求特别稳定,所以C++中把这些常用的模板做了统一的规范,慢慢的就形成了STL 提供三种类型的组件: 容器.迭代器和算法 ...
- 安装floodlight遇到的问题和解决
环境:ubuntu18.04 安装floodlight先前准备:java的环境,ant. sudo apt-get install build-essential defailt-jdk ant py ...
- Dispose的调用顺序
非托管资源的释放顺序. 这是应该先释放 reader 再释放 stream. 或者直接使用using,防止出错 .