优雅地把前端代码打包压缩发布到服务器

优雅的实现前端部署代码

  • 1.配置执行命令
  • 2.配置脚本内置参数
  • 3.编写脚本js,内部逻辑

一点知识点

compressing(文件压缩/解压)

  • 1.文件解压
    • // 将压缩包解压到 test 文件夹中 compressing.zip.uncompress('./test.zip','./test').then(() => { console.log('解压完成') }).catch(() => { console.log('解压失败') })
  • 2.文件压缩
    • compressing.zip.compressFile('E:/1.txt','E:/1.zip').then(() => { console.log('压缩完成') }).catch(() => { console.log('压缩失败') })

child_process(子进程)

  • node子进程,可以执行命令行命令,也就是cmd命令
  • 不影响主进程流程,主进程可以监听子进程状态
  • 子进程可以异步执行任务,和主进程共同执行
  • const exec = require('child_process').exec;

一个指令

npm run arrange // 执行脚本

一个package.json 配置

"scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "fb": "node ./fb.js", // 发布执行的js
    "eject": "react-scripts eject"
  },

一个ymn.json 配置

{
    "filePath":"build",
    ..., // 根目录下,添加一个json,相当于配置项
}

一个fb.js 脚本

    1. 利用exec执行打包指令
    1. 打包完成后,利用compressing进行压缩包创建
    1. 压缩包创建完成后,利用fs去读取buffer
    1. 将buffer利用axios发送给服务器,服务器进行数据存储
    1. 服务器收到数据后,将数据进行创建文件和文件类型。

直接上完整代码

const fs =require('fs');
const compressing = require('compressing');
const axios = require('axios')
const exec = require('child_process').exec;
let data =fs.readFileSync('./ymn.json')
const { filePath } = JSON.parse(data) ;
console.log('开始执行yarn build,进行打包项目');
exec('yarn build', (err, stdout, stderr) => {
        if (err) {
            return;
        }
        console.log('打包成功!');
        // 创建压缩包
        console.log('开始创建压缩包');
        let type = 'zip'
        let fileName =  new Date()*1
        compressing.zip.compressDir(`./${filePath}/`, `./${fileName}.${type}`).then(res=>{
            console.log('创建压缩包成功!',`${fileName}.${type}`);
            console.log('读取文件buffer');
            const buffer =fs.readFileSync(`./${fileName}.${type}`);
            console.log('读取文件buffer成功');
            return uploadfile(buffer,type,fileName)
        },(err)=>{console.log('压缩失败');})
        .then(res=>{
            console.log(res.data,'发送成功');
        })
})

const uploadfile = (buffer,type,fileName)=>new Promise((resolve, reject) => {
    console.log('开始上传文件');
    axios({
        method: 'post',
        url:  '127.0.0.1:3000',
        data: buffer,
        headers: { 'Content-Type': 'application/octet-stream', }, onUploadProgress: () => { }, 
    }).then(res=>{
        console.log('文件上传成功',res.data);
        fs.unlinkSync(`${__dirname}/${fileName}.${type}`)
        console.log('删除build文件成功',`${__dirname}/${fileName}.${type}`);
        resolve(res)
    }).catch(res=>{
        console.log('文件上传失败');
        fs.unlinkSync(`${__dirname}/${fileName}.${type}`)
        console.log('删除build文件成功');
        reject(res)
    })
})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
前端项目打包优化可以从以下几个方面入手: 1. 代码压缩:使用 webpack 的 UglifyJSPlugin 或 TerserPlugin 进行代码压缩,减小代码体积; ``` const UglifyJSPlugin = require('uglifyjs-webpack-plugin'); module.exports = { // ... optimization: { minimizer: [ new UglifyJSPlugin({ uglifyOptions: { compress: { warnings: false, drop_console: true,//去除console.log drop_debugger: true,//去除debugger pure_funcs: ['console.log']//指定移除的函数 } } }) ] } }; ``` 2. Tree shaking:使用 webpack 的 optimize.ModuleConcatenationPlugin 进行模块合并,减少代码冗余; ``` const webpack = require('webpack'); module.exports = { // ... plugins: [ new webpack.optimize.ModuleConcatenationPlugin() ] }; ``` 3. 懒加载:使用 webpack 的 import() 方法实现按需加载,减少首屏加载时间; ``` function getComponent() { return import(/* webpackChunkName: "lodash" */ 'lodash').then(_ => { var element = document.createElement('div'); element.innerHTML = _.join(['Hello', 'webpack'], ' '); return element; }).catch(error => 'An error occurred while loading the component'); } getComponent().then(component => { document.body.appendChild(component); }); ``` 4. CDN 加速:使用外部 CDN 加速加载常用库,减少服务器压力和网络请求时间; ``` <script src="https://cdn.bootcdn.net/ajax/libs/react/17.0.1/umd/react.production.min.js"></script> <script src="https://cdn.bootcdn.net/ajax/libs/react-dom/17.0.1/umd/react-dom.production.min.js"></script> ``` 5. 缓存优化:使用 webpack 的 hash 或 chunkhash 为打包文件添加哈希值,实现静态资源缓存,提高页面加载速度; ``` module.exports = { // ... output: { filename: '[name].[chunkhash].js', path: path.resolve(__dirname, 'dist') } }; ``` 以上是一些常见的前端项目打包优化方法,具体实现可以根据项目需求进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

家雀安知鸿鹄志

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值