Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 500|回复: 0

前端资源多个产品整站一键打包&包版本管理(四)—— js&css文件文件打包并生成哈希后缀,自动写入路径、解决资源缓存问题。

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-5-16 14:26:00 | 显示全部楼层 |阅读模式

    问题:

    当我们版本更新的时候,我们都要清理缓存的js跟css,如何使得在网页中不需要手动清理呢?

    答案:

    生成带有哈希后缀的js跟css文件

     

    1、文件路径

     

     

    路径中的conf.js 是用于放置全局打包的公共方法的、

    conf.team.json 则是用于放置 team 这个项目的打包路径 、

    gulpfile.team.js 用于写 team 这个项目的打包、

    打包前的文件放在build中、打包后的文件放在dist中

     

     

    总的打包任务在webapp 根目录下

     

     

     

     为什么要这样放置目录,请看 gulp分流

     

     

     

    2、我们在conf.team.json 里面配置 css 里面的user 文件夹

     

     

    {
      "cssUser":[
        "./build/team/stylesheets/user/**/*.css",
        "./build/team/stylesheets/user/*.css"
      ]
    }

     

     

     

     有人会问:为什么使用"./build/team...  而不是使用 "./team 呢 我们可以看到 虽然 gulpfile.team.js  跟team 文件夹是同一级目录的,

    但是我们最终打包执行的文件是 gulpfile.js ,由 gulpfile.js  内部引用 gulpfile.team.js

    而 gulpfile.js跟 build在同一个目录 在webapp目录下的

     

     

    因此我们在引用路径的时候,一切以 gulpfile.js 为主

     

    3、打包 css 文件

     

    下面实在 gulpfile.team.js 里面引入所需要的工具 下面工具我们将会一一讲解

    /**
     * Created by 何Mickey on 11/7/2016.
     */
    "use strict";
    const fs = require('fs');
    const gulp = require('gulp');
    const clean = require('gulp-clean');
    const pump = require('pump');
    const del = require('del');
    const path = require('path');
    const concat = require('gulp-concat');
    const modify = require('gulp-modify');
    const uglifyjs = require('uglify-js');
    const minifier = require('gulp-uglify/minifier');
    const less = require('gulp-less');
    const cleanCSS = require('gulp-clean-css');
    const rev = require('gulp-rev');
    const sort = require('gulp-sort');
    const sourcemaps = require('gulp-sourcemaps');
    const csscomb = require('gulp-csscomb');
    const rename = require('gulp-rename');
    const strip = require('gulp-strip-comments');
    
    const conf = require('./conf/conf.js');  //引入公共的函数
    const jsonConf = require('./conf/conf.team.json');   //引入打包路径

     

    gulp.task('css-team-user',['less-team'],(cb) => {
        //清除上一版本的残留
        del(['./dist/team/stylesheets/team-user-*.css']).then(paths => {  //del插件可以删除给定链接的文件,这里我们要删除上一次的哈希文件,
            pump([                                                        //如果不删除,在下一次生成哈希文件的时候,会在原来的基础上追加后缀,这是我们不希望看到的
                gulp.src(jsonConf.cssUser),
                modify({
                    fileModifier: conf.clearCSSCharset  
                }),
                csscomb(),                  //gulp-csscomb 插件用于整理css格式
                cleanCSS(),                //gulp-clean-css用于压缩css文件 
                concat('team-user.css'),   //压缩到team-user.css文件里面
                gulp.dest('./dist/team/stylesheets/'),  //把压缩好的文件放在改目录下
            ],cb);
        });
    });

    在webapp目录下执行

    gulp css-team-user

    就会在

    生成一个打包好的css文件

     

     

    4、生成带哈希后缀的css文件

     

    这里用到gulp-rev 插件,用于生成带哈希后缀的文件 并把文件名写入 json文件

     

    gulp.task('team-resource',['css-team-user'],cb => {
        del(['./dist/team/manifest.json']).then(paths => {
            pump([
                gulp.src([
                    './dist/team/stylesheets/*.css'
                ], {base: './dist/team'}),
                rev(),  //生成带哈希后缀的文件
                gulp.dest('./dist/team'),
                rev.manifest('./dist/team/manifest.json', {  //并把源文件路径 和 哈希文件路径 以属性值的方式写在 manifest.json 里面
                    base: './dist/team',
                    merge: false
                }),
                gulp.dest('./dist/team'),
            ], cb);
        });
    });

     

    于是我们就可以看到

    成功生成了一个哈希文件

    并且生成了一个manifest.json 在目录下,我们打开该文件 里面有:

     

    {
      "javascripts/team-user.js": "javascripts/team-user-201ef04fd5.js",
    }

     

    这时 任务完成了?已经生成了哈希后缀的文件了,但是事情还没结束,我们还能做得更好,如果我们每次都要把生成后的哈希值在代码的资源引入里面修改,会很麻烦

    而且线上打包也不允许我们这样子做,那我们说好的一键打包呢? 接下来就是我们要做的了:

     

     5、把带哈希后缀的文件链接写入文件

     

    let manifest = null;
    let loadTeamMainfest = () => {
        if(!manifest) manifest = require('../dist/team/manifest.json');  //引入manifest.json 文件里面的属性值对 
    };

     引入对象

     

    gulp.task('build-team',['team-resource'],cb => {
        //需要等待文件生成后再load
        loadTeamMainfest(); //
        let kv = {};
        for(let key of Object.keys(manifest)){
            kv[key] = '/dist/team/'+manifest[key];
        }
        let cssTeamUser = `<link type="text/css" rel="stylesheet" href="${kv['stylesheets/team-user.css']}">\n`
            
        fs.writeFile('./WEB-INF/templates/team/common/link/css_min.vm',cssTeamUser,'utf8');
        
    });

     

    这样我们就可以打开

    './WEB-INF/templates/team/common/link/css_min.vm' 

    <link type="text/css" rel="stylesheet" href="/dist/team/stylesheets/team-user-a1a05e86f5.css">

     

    于是就成功滴引入了带有哈希后缀的资源文件了、从此资源缓存都是浮云了~

    其实这个方法在线上还是会有问题的,在使用js带哈希的文件的时候,通常一个网站的资源要部署到不同的机器上,而js的打包是一个不稳定的打包,这样的版本会因为部署时间差,带来困扰。
    过几天,我会给大家带来另一个带哈希的后缀的打包方法~~


    如有不对之处,欢迎指出~~喵~~

    夜深了、洗洗睡睡、敷面膜吧~~~



     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-23 12:20 , Processed in 0.060942 second(s), 28 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表