smartload39smart团队原创,主要实现前端css/js一次加载请求,永久缓存的加速效果,在移动端效果非常明显.

插件特点:


  • 支持平台: PC和移动端所有版本浏览器,ie6+,firefox,chrome,uc,safari等等...
  • 核心功能: 全站css/js版本统一管理,同步或异步加载,老中新三代浏览器的css/js分离
  • 存储支持: indexDB > Web SQL > localStorage > 无缓存.
  • 实现原理:自动载入适合的版本,v1适合无localStorage版本浏览器(如ie8以下)直接加载,v2适合支持不支持async/await等ES7特性的版本使用Promise异步加载(ie8+,ff52-,chrome55-),v3则适合手机端及PC端各个支持ES7的浏览器.
  • 使用要求:css/js等资源必须与插件使用站点可跨域 (ajax正文进行存储需要)

使用方法:

1.上传插件包至服务器中
2.页面引入:<script type="text/javascript" src="youpath/entrance.js" async=""></script>
3.注意,页面中除以上无需任何其它<style>或<script>,以便实现版本和内容统一调度和管理.
4.按下方配置方法在entrance.js中进行配置.
5.除了配置中的预加载项,可在其余js中使用smartload.load()独立加载.

独立引入方法:

smartload.load(_preload);//如由entrance.js中引入的test.js中使用.
_preload方法参照配置中的示例:(String,Array)
String:
'jquery'//单独加载
'jquery.ui,jquery.form,jq'//批量异步
['jquery','jquery.ui'...]//批量同步加载
['jquery',['jquery.ui','jquery.form']...]//同异步并行,本示例先载入jquery,再异步载入ui和form
[['youscript','yourcss'...],['jquery.ui','jquery.form'...]...]//css或js均可混合同异步

注意与解释:

1.所有域名(如domain.css)均不要以'/'结尾.资源必须可跨域.
2.命令行:
格式:[plugin_name][类型.版本信息][回调方法]路径或url
其中:
[plugin_name]:唯一键,切勿重复,选填
//若已有对象的键名,则可不填如:'plugin_name':'[css].....';
[类型.版本信息]:类型必填.如css或js,版本信息选填
//例如[css]或[css.v5.0],5.0这样的版本如果改动了,会引起该文件的增量更新.
[回调方法名]:选填,载入url后的回调
//例如[callback]
路径或url:必填,路径则不包括后缀名,url则完整地址
//例如[test]=地址为/test.js
//[http:127.0.0.1/abc.js]
//[test,http:127.0.0.1/abc.js]//逗号之后为后备地址,可多个
3.命令包:
参见smartloadConfig.list;
_preload预加载项

配置信息:

var smartloadConfig={//js中务必var,let等均不被低版本支持.
entrance: {//入口地址:
base_css:'your css code',//该css为网站基本css内容用于最初的css渲染,如loading效果
file:'[js.v0.8.1]smartload/{$}',//命令行,{$}会被自动替换为自适应版本.
debug:'true'//是否打开调试,默认false;
},
config:{//配置信息:更新时将清理客户端缓存,进行全量更新.
name:'yourname',//必填,自定义的本地缓存库名称,
version:'v1.0',//必填,改动则全量更新
domain:{//域名,必填,格式如下,domain.css和domain.js必填.其余任意
//例如加了'test:'http://abc.com'之后.如被缓存的文件中存在`_domain.test_`则会被替换.
css:'http://127.0.0.1',//或http://www.test.com/css等
js:'http://127.0.0.1',//如果文件中存在_domain.css_,_domain.js_,_domain.img_将被替换为该值
img:'https://css.test.com'
}
},
list:{//命令包,选填:格式如下,_preload是系统内置值
_preload:[//预加载项,true=全部异步加载,false=按顺序加载.数组
//数组示范:
//['abc','hello']=依次加载abc和hello
//['abc',['ni','hao']]//依次加载abc后并行加载ni,hao
//示范['jquery',['jquery.form','jquery.cookie'],'myformcode','mycookiecode']
'_promise',
['_promise2'],
['_localforage','_localforage2'],
['_smartload','_smartload2']
],
//命令行
_promise:'[js.v0.8.1]promise,https://abc.com/0.8.1/test.js'
}
};

测试结论:

除v1使用了系统默认load外,其余均一次请求,永久缓存.除非用户手动或代码删除,否则将永久存储.极大的减少服务器流量,提升用户访问体验.
区别于304等与页面阻塞,插件速度更快,版本管理更容易,异步无阻塞.
v1=浏览器默认方式,性能无差.
v2=性能较浏览器提升4-6倍
v3=由于async/await的支持,性能是v2的6-8倍,v1版的24-32倍.


本插件39smart团队原创,原创版权所有!

smartload跨浏览器极速缓存插件用法的更多相关文章

  1. jQuery插件:跨浏览器复制jQuery-zclip

    jQuery-zclip是一个复制内容到剪贴板的jQuery插件,使用它我们不用考虑不同浏览器和浏览器版本之间的兼容问题.jQuery-zclip插件需要Flash的支持,使用时记得安装Adobe F ...

  2. ZeroClipboard / jquery.zclip.min.js跨浏览器复制插件使用中遇到的问题解决

    之前写过一个淘宝优惠券连接PC端转手机端连接的小工具,当时写到将转换好的url复制到剪切板这块时解决了IE和火狐,就是没办法搞定Chrome,知道可以通过flash搞定,但是觉得太麻烦没有仔细研究. ...

  3. 跨浏览器实现placeholder效果的jQuery插件

    曾经遇到这样一个问题,处理IE8密码框placeholder属性兼容性.几经周折,这个方案是可以解决问题的. 1.jsp页面引入js插件 <script type="text/java ...

  4. Microsoft SilverLightt是一个跨浏览器的、跨平台的插件,为网络带来下一代基于.NETFramework的媒体体验和丰富的交互式应用程序。

    Microsoft Silverlight是一个跨浏览器的.跨平台的插件,为网络带来下一代基于.NETFramework的媒体体验和丰富的交互式应用程序.Silverlight提供灵活的编程模型,并可 ...

  5. 能跨域和跨浏览器的flashcookie for jquery插件

    对于写网站时需要跨域和跨浏览器的可以看看这个. 引入jquery  和 swfstore.min.js 就可以了,蛮简单好用的,会jquery基础就可以咯. mySwfStore.set('myKey ...

  6. 跨浏览器的事件对象-------EventUtil 中的方法及用法

    什么是EventUti----封装好的事件对象 在JavaScript中,DOM0级.DOM2级与旧版本IE(8-)为对象添加事件的方法不同 为了以跨浏览器的方式处理事件,需要编写一段“通用代码”,即 ...

  7. DalekJS – 基于 JavaScript 实现跨浏览器的自动化测试

    在 Web 项目中,浏览器兼容以及跨浏览器测试是最重要的也是最费劲的工作.DalekJS 是一个基于 JavaScript(或 Node.js) 的免费和开源的自动化测试接口.它能够同时运行测试一组流 ...

  8. Socket.IO – 基于 WebSocket 构建跨浏览器的实时应用

     Socket.IO 是一个功能非常强大的框架,能够帮助你构建基于 WebSocket 的跨浏览器的实时应用.支持主流浏览器,多种平台,多种传输模式,还可以集合 Exppress 框架构建各种功能复杂 ...

  9. 缓存插件 EHCache

    EHCache是来自sourceforge(http://ehcache.sourceforge.net/)的开源项目,也是纯Java实现的简单.快速的Cache组件. 下载jar包 Ehcache ...

随机推荐

  1. Magento开发基础知识之RequireJs

    一.RequireJS概述 RequireJS是一个工具库,主要用于客户端的模块管理.实现异步或动态加载,从而提高代码的性能和可维护性. RequireJS的基本思想是,通过define方法,将代码定 ...

  2. springboot2.0自适应效果错误响应

    实现效果当访问thymeleaf渲染页面时,显示的是自定义的错误页面 当以接口方式访问时,显示的是自定义的json数据响应 1. 编写自定义异常 package cn.jfjb.crud.except ...

  3. PhpStorm配置Xdebug调试

    安装xdebug 去官网下载对应版本的xdebug扩展 XDEBUG EXTENSION FOR PHP | DOWNLOADS 如何选择正确版本 输出phpinfo()函数的内容 查看输出页面的网页 ...

  4. sys模块&json模块&pickle模块

    sys模块&json模块&pickle模块 sys模块 一.导入方式 import sys 二.作用 与Python解释器交互 三.模块功能 3.1 经常使用 sys.path #返回 ...

  5. python里面列表函数的使用及注意

    1.append 在末尾插入一个内容: a= [i for i in range(1,6)] print(a) a.append(100) print(a) 2.insert 指定位置插入内容 ins ...

  6. CSS 相对定位 绝对定位

    css中的相对定位和绝对定位. 定位标签:position 包含属性:relative(相对) absolute(绝对) 1.position:relative; 如果对一个元素进行相对定位,首先它将 ...

  7. redis远程连接配置

    解决redis远程连接不上的问题 redis现在的版本开启redis-server后,redis-cli只能访问到127.0.0.1,因为在配置文件中固定了ip,因此需要修改redis.conf(有的 ...

  8. 记录-- vue+element树节点的标注

    html(背景:状态标注3钟颜色红黄绿对应0,1,2,) <el-tree @check="slclasscheck" v-if="treeShow" : ...

  9. LVS实现负载均衡原理及安装配置 负载均衡

    LVS实现负载均衡原理及安装配置 负载均衡集群是 load balance 集群的简写,翻译成中文就是负载均衡集群.常用的负载均衡开源软件有nginx.lvs.haproxy,商业的硬件负载均衡设备F ...

  10. At grand 024

    A /* Huyyt */ #include <bits/stdc++.h> #define mem(a,b) memset(a,b,sizeof(a)) #define mkp(a,b) ...