当前位置:  软件>JavaScript软件

js本地存储和增量更新 rstoreinc

    来源:    发布时间:2014-12-26

    本文导语:  **js本地存储和增量更新requirejs插件使用**----------------------------**用增量更新这个算法写了一个requirejs插件storeinc,使用方法如下:****首先使用修改后的r.js来进行混淆打包,构建配置如下(请看js/requirejs下的build.js):**    ({        a...

**js本地存储和增量更新requirejs插件使用**
----------------------------

**用增量更新这个算法写了一个requirejs插件storeinc,使用方法如下:**
**首先使用修改后的r.js来进行混淆打包,构建配置如下(请看js/requirejs下的build.js):**

    ({
        appDir: "../demo/js",
        baseUrl: "./",
        dir: "../demo/dist",//不走增量更新的文件存放路径
        paths: {
            log: "a",
            storeinc:"../storeinc"//这里插件
        },
        storeinc: true,//说明走storeinc插件
        storedir: "../demo/storeincdist",//混淆后的js存放路径,包括增量文件
        lastver:"2", //上一个版本号,如果没有说明是第一次打包
        ver:'3',//新版版本号
        chunkSize:12,//增量更新块号
        modules: [
            {
                name: "test",
                exclude: [
                    "log","b","c","d","storeinc"
                ]
            },
            {
                name: "log",
                exclude: [
                   "storeinc"
                ]
            },
            {
                name: "b",
                exclude: [
                    "storeinc","log"
                ]
            },
        ]
    
    })


**运行node r.js -o build.js**

**第一次运行时:**
    lastver:"1", //上一个版本号,如果没有说明是第一次打包
    ver:'2',//新版版本号


**然后到js目录修改各个源文件,第二次运行时:**
    lastver:"2", //上一个版本号,如果没有说明是第一次打包
    ver:'3',//新版版本号
  

**然后在index.html里面加入如下代码(请看js/requirejs下的index.html):**
 

 


  //storeinc相关配置
var require = {
ver:"3",//当前版本
storeproxy:false,//是否使用代理方式来计算增量更新
paths: {
storeinc: '../storeinc'//增量更新插件路径
}
};


    //主资源下载,记住storeinc!前缀来启用插件
   


   


requirejs.config({
paths: {
log: [`enter code here`
'a'
],
b: [
'b'
],
c: [
'c'
],
d: [
'd'
],
e: [
'e'
]
}
});




另外需要在业务里的各个依赖前都加上storeinc!如test.js:


    require(['storeinc!log','storeinc!c','storeinc!d'], function (log, modC, modD) {
        log.write('test3 run!!');
        log.write('module c's name is ' + modC.name);
        log.write('module d's name is ' + modD.name);
    });


**接下来看下效果:**
**第一次我们把index.html里的ver项配置设为2,然后访问index.html,发现访问的是test-2.js等版本为2的js**
**第二次我们把index.html里的ver项配置设为3,说明这次需要的是版本为3的内容,发现访问的是test-2_3.js**
**说明访问的是增量文件,已经达到增量更新的目的**
  


    
 
 

您可能感兴趣的文章:

 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • SQLServer用存储过程实现插入更新数据示例
  • sql server中批量插入与更新两种解决方案分享(存储过程)
  • 揭秘SQL Server 2014有哪些新特性(3)-可更新列存储聚集索引
  • 动态给表添加删除字段并同时修改它的插入更新存储过程
  • java将类序列化并存储到mysql(使用hibernate)
  • 在SQL Server中使用SQL语句查询一个存储过程被其它所有的存储过程引用的存储过程名
  • 服务器存储快照和数据库快照详解
  • java调用sql server存储过程,如何取存储过程返回码(不是结果集)
  • docker中文入门学习手册 iis7站长之家
  • MYSQL存储过程里代返回值的存储过程怎么写
  • mysql 存储过程实例和基本语法
  • 用C或C++编程,模拟可变分区存储管理且首次适应的算法实现存储器的分配与回收
  • 数据库存储, 改用TXT文件存储
  • 用proceduredataset孔件来调用存储过程时,要用到其属性procedure.我自己写好的存储过程如何放在里面?
  • 这句话什么意思:“分页存储管理是一个单一的线性地址空间,分段存储管理的作业地址空间是二维的。”?
  • 急求 unix 与linux在文件存储上 和数据存储上有哪些不同 希望各路英雄帮忙
  • 请问各位大侠怎样在java中调用存储过程和接受存储过程的返回参数
  • 请教:如何选购NAS网络存储器?做视频服务器的存储用。急!!!
  • 分享:在存储过程中使用另一个存储过程返回的查询结果集的方法
  • 分页存储过程(用存储过程实现数据库的分页代码)
  • Mysql存储过程学习笔记--建立简单的存储过程
  • 数据库存储还是直接存储在硬盘上好?(来者有分)
  • sqlserver 批量删除存储过程和批量修改存储过程的语句
  • oracle分页存储过程 oracle存储过程实例
  • 急!50分!我现在想要在VECTOR中直接存储结果集???但不想使用"在VECTOR中存储一个


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3