动态加载/删除css文件以及图片预加载
 
功能模块页面
 
最近,工作中遇到了一个比较奇葩的需求:要在一个页面(PC端)增加一个功能模块,但是这个页面在不久之后要重构,为了新增加的模块可以继续复用,必须做到这个模块的样式对页面其他模块不能造成影响,旧版页面使用bootstrap样式,新版模块只使用normalize.css,UI组件使用sass重写,因为重构工作量太大,公司前端只有1+1个人,所以就想将模块样式独立,最后,用动态加载link标签解决。
 
上图为一个页面,所有模块通过哈希控制是否显示,新增了一个约标模块。附上自认为很low的解决方放:(欢迎指正不足)
  1. // 添加link标签
  1. this.loadCss = function(url, callback) {
  1. var link = document.createElement('link');
  1. link.type="text/css";
  1. link.rel = "stylesheet";
  1. link.href = url+'1';
  1. document.getElementsByTagName('head')[0].appendChild(link);
  1. if (callback) {
  1. callback.call(link);
  1. }
  1. }
  1. // 通过判断是否为新增模块
  1. if("#" + relId == "#setup_12"){
  1. self.loadCss('/css/v2.0/pc/new_main.css?v=201702231412', function(){
  1. self.$_link = this;
  1. })
  1. self.loadCssComplete('/css/v2.0/pc/new_main.css?v=201702231412', function(){
  1. $("#" + relId).show();  //判断css是够加载完成,如果完成则显示模块
  1. })
  1. }else{
  1. if($.isEmptyObject(self.$_link)){
  1. console.log($.isEmptyObject(self.$_link))
  1. }else{
  1. document.getElementsByTagName('head')[0].removeChild(self.$_link);
  1. self.$_link = new Object();
  1. window.location.reload();  // 在切换tabs时删除link标签并刷新避免缓冲造成影响
  1. }
  1. $("#" + relId).show();
  1. }
将link标签添加到最后,避免bootstrap样式发生覆盖。
特此分享,希望对一些和我一样low的FED有帮助。

附上最近工作中用到的图片资源预加载并显示加载进度条代码:
  1. //构造器函数
  1. function resLoader(config){
  1. this.option = {
  1. resourceType : 'image', //资源类型,默认为图片
  1. baseUrl : './', //基准url
  1. resources : [], //资源路径数组
  1. onStart : null, //加载开始回调函数,传入参数total
  1. onProgress : null, //正在加载回调函数,传入参数currentIndex, total
  1. onComplete : null //加载完毕回调函数,传入参数total
  1. }
  1. if(config){
  1. for(i in config){
  1. this.option[i] = config[i];
  1. }
  1. }
  1. else{
  1. alert('参数错误!');
  1. return;
  1. }
  1. this.status = 0; //加载器的状态,0:未启动   1:正在加载   2:加载完毕
  1. this.total = this.option.resources.length || 0; //资源总数
  1. this.currentIndex = 0; //当前正在加载的资源索引
  1. };
 
  1. resLoader.prototype.start = function(){
  1. this.status = 1;
  1. var _this = this;
  1. var baseUrl = this.option.baseUrl;
  1. for(var i=0,l=this.option.resources.length; i<l; i++){
  1. var r = this.option.resources[i], url = '';
  1. if(r.indexOf('http://')===0 || r.indexOf('https://')===0){
  1. url = r;
  1. }
  1. else{
  1. url = baseUrl + r;
  1. }
 
  1. var image = new Image();
  1. image.onload = function(){_this.loaded();};
  1. image.onerror = function(){_this.loaded();};
  1. image.src = url;
  1. }
  1. if(isFunc(this.option.onStart)){
  1. this.option.onStart(this.total);
  1. }
  1. };
  1. resLoader.prototype.loaded = function(){
  1. if(isFunc(this.option.onProgress)){
  1. this.option.onProgress(++this.currentIndex, this.total);
  1. }
  1. //加载完毕
  1. if(this.currentIndex===this.total){
  1. if(isFunc(this.option.onComplete)){
  1. this.option.onComplete(this.total);
  1. }
  1. }
  1. };
  1. var loader = new resLoader({
  1. resources : [
  1. ],
  1. onStart : function(total){
  1. self.$loadingId.innerText='0%';
  1. self.$loadingIcon.style.left = '0%';
  1. self.$loadingCon.style.width = '0%';
  1. },
  1. onProgress : function(current, total){
  1. var percent =Math.floor(current/total*100);
  1. self.$loadingId.innerText=percent + '%';
  1. self.$loadingIcon.style.left = percent + '%';
  1. self.$loadingCon.style.width = percent + '%';
  1. },
  1. onComplete : function(total){
  1. self.$loadingId.innerText='100%';
  1. self.$loadingIcon.style.left = '100%';
  1. self.$loadingCon.style.width = '100%';
  1. document.getElementById('page_loading').style.display = 'none';
  1. }
  1. });
  1. loader.start();
一枚不会写文章的程序员~

动态加载/删除css文件以及图片预加载的更多相关文章

  1. webpack模块加载css文件及图片地址

    webpack支持css文件加载并打包,只需安装相应加载器并在配置文件中配置 . 加载的css文件内容会与该模块里的js内容混合封装,这样做的好处是一个js文件包含了所有的css与js内容,有效减少了 ...

  2. js动态加载js css文件,可以配置文件后辍,防止浏览器缓存

    js的引用,在浏览器,或微信上访问经常会遇到文件改了,但就是没有更新的问题,使用此函数可以轻松解决缓存问题只需要把js的引用方式改为使用此函数加载即可 源码如下: /** * js动态加载js css ...

  3. 页面加载异常 清除浏览器静态文件 js css 缓存 js动态加载js css文件,可以配置文件后辍,防止浏览器缓存

    js清除浏览器缓存的几种方法 - 兔老霸夏 - 博客园 https://www.cnblogs.com/Mr-Rocker/p/6031096.html js清除浏览器缓存的几种方法   一.CSS和 ...

  4. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  5. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法(转)

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  6. Javascript图片预加载详解 分类: JavaScript HTML+CSS 2015-05-29 11:01 768人阅读 评论(0) 收藏

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  7. 图片预加载 js css预加载

    图片预加载, 效果非常明显, 特别是有多个图, 方法很简单 , 体验提升了不少 <div class="hidden">        <script type= ...

  8. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法及优缺点分析

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  9. javascript异步延时加载及判断是否已加载js/css文件

    <html> <head> <script type="text/javascript"> /**======================= ...

随机推荐

  1. hdu-1231 连续最大子序列(动态规划)

    Time limit1000 ms Memory limit32768 kB 给定K个整数的序列{ N1, N2, ..., NK },其任意连续子序列可表示为{ Ni, Ni+1, ..., Nj ...

  2. Kattis - doubleclique (图论)

    From : North American Invitational Programming Contest 2018 给你一个图,以及它的补图.如果部分点在原图中是团,并且其他的所有点在补图中也是团 ...

  3. LAMP动态网站安装脚本

    #!/bin/bash #auto make install LAMP #by authors zhangjianghua #httpd define path variable H_FILES=ht ...

  4. Windows和linux(ubuntu)互传文件简便快捷的方法

    现在很多开发和测试的工作环境都是Linux,但测试后期报告的处理一般都是在Windows下完成的,所以需要把结果拿到Windows下. 如果是同一台PC还好些(windows下安装linux的虚拟机, ...

  5. 搭建基于金山快盘的Git服务器

    最近迷上了Git,这货堪称神器,用了它就再也不想用其他VCS了,就像上了高速就不想再走国道一样. 一般人使用Git+Github来搭建进行本地远程交互,不过Github弄个私人仓库是要刀乐思的,如果你 ...

  6. Scala学习-01-变量与类型

    Scala运行在jvm之上,可以调用Java类库和与Java框架交互,并将面向对象与面向函数结合在一起. 特点: 1 保留了静态类型检查.安全保障高. 2 函数式编程,更加灵活. 3 运行于jvm之上 ...

  7. mvc “System.NullReferenceException”类型的异常在 App_Web_zo44wdaq.dll 中发生,但未在用户代码中进行处理 其他信息: 未将对象引用设置到对象的实例。

    “System.NullReferenceException”类型的异常在 App_Web_zo44wdaq.dll 中发生,但未在用户代码中进行处理 其他信息: 未将对象引用设置到对象的实例. 解决 ...

  8. 《机器学习实战》笔记——AdaBoost

    笔记见备注 # _*_ coding:utf-8 _*_ from numpy import * # 简单数据集 def loadSimpData(): datMat = matrix([[1., 2 ...

  9. [python篇] [伯乐在线][1]永远别写for循环

    首先,让我们退一步看看在写一个for循环背后的直觉是什么: 1.遍历一个序列提取出一些信息 2.从当前的序列中生成另外的序列 3.写for循环已经是我的第二天性了,因为我是一个程序员 幸运的是,Pyt ...

  10. springboot获取getBean方法以及ApplicationContext空指针问题解决

    创建获取ApplicationContext工具类: package com.performancetest.common.utils; import org.springframework.bean ...