动态加载/删除css文件以及图片预加载
- // 添加link标签
- this.loadCss = function(url, callback) {
- var link = document.createElement('link');
- link.type="text/css";
- link.rel = "stylesheet";
- link.href = url+'1';
- document.getElementsByTagName('head')[0].appendChild(link);
- if (callback) {
- callback.call(link);
- }
- }
- // 通过判断是否为新增模块
- if("#" + relId == "#setup_12"){
- self.loadCss('/css/v2.0/pc/new_main.css?v=201702231412', function(){
- self.$_link = this;
- })
- self.loadCssComplete('/css/v2.0/pc/new_main.css?v=201702231412', function(){
- $("#" + relId).show(); //判断css是够加载完成,如果完成则显示模块
- })
- }else{
- if($.isEmptyObject(self.$_link)){
- console.log($.isEmptyObject(self.$_link))
- }else{
- document.getElementsByTagName('head')[0].removeChild(self.$_link);
- self.$_link = new Object();
- window.location.reload(); // 在切换tabs时删除link标签并刷新避免缓冲造成影响
- }
- $("#" + relId).show();
- }
- //构造器函数
- function resLoader(config){
- this.option = {
- resourceType : 'image', //资源类型,默认为图片
- baseUrl : './', //基准url
- resources : [], //资源路径数组
- onStart : null, //加载开始回调函数,传入参数total
- onProgress : null, //正在加载回调函数,传入参数currentIndex, total
- onComplete : null //加载完毕回调函数,传入参数total
- }
- if(config){
- for(i in config){
- this.option[i] = config[i];
- }
- }
- else{
- alert('参数错误!');
- return;
- }
- this.status = 0; //加载器的状态,0:未启动 1:正在加载 2:加载完毕
- this.total = this.option.resources.length || 0; //资源总数
- this.currentIndex = 0; //当前正在加载的资源索引
- };
- resLoader.prototype.start = function(){
- this.status = 1;
- var _this = this;
- var baseUrl = this.option.baseUrl;
- for(var i=0,l=this.option.resources.length; i<l; i++){
- var r = this.option.resources[i], url = '';
- if(r.indexOf('http://')===0 || r.indexOf('https://')===0){
- url = r;
- }
- else{
- url = baseUrl + r;
- }
- var image = new Image();
- image.onload = function(){_this.loaded();};
- image.onerror = function(){_this.loaded();};
- image.src = url;
- }
- if(isFunc(this.option.onStart)){
- this.option.onStart(this.total);
- }
- };
- resLoader.prototype.loaded = function(){
- if(isFunc(this.option.onProgress)){
- this.option.onProgress(++this.currentIndex, this.total);
- }
- //加载完毕
- if(this.currentIndex===this.total){
- if(isFunc(this.option.onComplete)){
- this.option.onComplete(this.total);
- }
- }
- };
- var loader = new resLoader({
- resources : [
- ],
- onStart : function(total){
- self.$loadingId.innerText='0%';
- self.$loadingIcon.style.left = '0%';
- self.$loadingCon.style.width = '0%';
- },
- onProgress : function(current, total){
- var percent =Math.floor(current/total*100);
- self.$loadingId.innerText=percent + '%';
- self.$loadingIcon.style.left = percent + '%';
- self.$loadingCon.style.width = percent + '%';
- },
- onComplete : function(total){
- self.$loadingId.innerText='100%';
- self.$loadingIcon.style.left = '100%';
- self.$loadingCon.style.width = '100%';
- document.getElementById('page_loading').style.display = 'none';
- }
- });
- loader.start();
动态加载/删除css文件以及图片预加载的更多相关文章
- webpack模块加载css文件及图片地址
webpack支持css文件加载并打包,只需安装相应加载器并在配置文件中配置 . 加载的css文件内容会与该模块里的js内容混合封装,这样做的好处是一个js文件包含了所有的css与js内容,有效减少了 ...
- js动态加载js css文件,可以配置文件后辍,防止浏览器缓存
js的引用,在浏览器,或微信上访问经常会遇到文件改了,但就是没有更新的问题,使用此函数可以轻松解决缓存问题只需要把js的引用方式改为使用此函数加载即可 源码如下: /** * js动态加载js css ...
- 页面加载异常 清除浏览器静态文件 js css 缓存 js动态加载js css文件,可以配置文件后辍,防止浏览器缓存
js清除浏览器缓存的几种方法 - 兔老霸夏 - 博客园 https://www.cnblogs.com/Mr-Rocker/p/6031096.html js清除浏览器缓存的几种方法 一.CSS和 ...
- 利用CSS、JavaScript及Ajax实现图片预加载的三大方法
预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...
- 利用CSS、JavaScript及Ajax实现图片预加载的三大方法(转)
预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...
- Javascript图片预加载详解 分类: JavaScript HTML+CSS 2015-05-29 11:01 768人阅读 评论(0) 收藏
预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...
- 图片预加载 js css预加载
图片预加载, 效果非常明显, 特别是有多个图, 方法很简单 , 体验提升了不少 <div class="hidden"> <script type= ...
- 利用CSS、JavaScript及Ajax实现图片预加载的三大方法及优缺点分析
预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...
- javascript异步延时加载及判断是否已加载js/css文件
<html> <head> <script type="text/javascript"> /**======================= ...
随机推荐
- The 2018 ACM-ICPC China JiangSu Provincial Programming Contest I. T-shirt
JSZKC is going to spend his vacation! His vacation has N days. Each day, he can choose a T-shirt to ...
- HDU 5473 There was a kingdom 凸包 DP
题意: 给出平面上n个点的坐标,选k个点,使得这k个点围起来的面积最大. 分析: 参考了 叉姐的分析 和 不慌不忙菊苣的代码 思路我都懂,但是DP的部分还是不太会写. 我体会了一下其中含义,也许这样可 ...
- Notepad++ 使用正则表达式查找替换字符串
最近在改一些别人写的PHP代码,由于之前的代码可维护性比较差,因此工作量比较多,因此想找一些高效的方式改一些有规律的代码. 比如: 我想将一些类似$rowss[MaxGetCash_num], ...
- STL学习笔记2--list
List --- 双向列表 List是线性列表结构,数据查找需要一个接一个,不能直接得到元素地址,检索时间与目标元素的位置成正比.但是插入数据比较快,可以在任何位置插入数据或者删除数据.list特点是 ...
- Linux安装Scala
下载Scala地址http://downloads.typesafe.com/scala/2.10.6/scala-2.10.6.tgz然后解压Scala到指定目录 tar -zxvf scala-2 ...
- 利用bochs调试Linux 0.11内核
引导程序调试软件bochs,跟配套的linux0.11内核img下载地址分别是: http://sourceforge.net/projects/bochs/http://www.oldlinux.o ...
- [adb 学习篇] adb pull
adb pull E:\uitest\testcase\CaseDemo\testcase\3dmark\3DMarkAndroid /sdcard/3DMarkAndroid 假设: E: ...
- 九度oj 题目1513:二进制中1的个数
题目描述: 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. 输入: 输入可能包含多个测试样例. 对于每个输入文件,第一行输入一个整数T,代表测试样例的数量.对于每个测试样例输入为一个 ...
- 【Luogu】P1411树(树形高精DP)
题目链接 我貌似又做了一道高精题呢(笑) 这题的DP方程很好想,设f[i][j]表示i为根的子树,i所在联通块大小为j的最大值,然后乱搞 但是要高精,那么搞是得要高精除的 所以考虑f[i][j]是除以 ...
- jquery工具方法总结
$.extend 对象合并,支持深拷贝 $.each 相当于array.each或object.each,可以遍历数组和对象 $.grep 相当于array.filter $.map 相当于array ...