环境

win10 + webstorm 2019.1.3 + node 12.x + yarn

实现的的功能

  1. 基本的js打包(支持规范:ES6 module | requirejs | commonjs)
  2. 打包样式css、less,样式的模块化 ,增加样式的厂商前缀
  3. 打包字体
  4. 打包图片(小于8K的转base64字符串)
  5. 自动注入打包后的js文件
  6. 自动清理打包目录(只留下最后一次成功打包的文件)

文件结构

.
├── bulid-webpack.config.js //生成模式配置
├── dev-webpack.config.js //开发模式配置
├── dist //打包后的目录
│   ├── 07d95431--app.js
│   ├── 07d95431--app.js.map
│   ├── 524c08db--iconfont.eot
│   ├── a8ed3992--iconfont.woff
│   ├── c4b92501--iconfont.svg
│   ├── f4a753e6--iconfont.ttf
│   ├── images
│   │   └── 83ac0039--1.png
│   └── index.html
├── package.json
├── postcss.config.js
├── src
│   ├── fonts //字体
│   │   ├── iconfont.css
│   │   ├── iconfont.eot
│   │   ├── iconfont.svg
│   │   ├── iconfont.ttf
│   │   ├── iconfont.woff
│   │   └── iconfont.woff2
│   ├── images //图片
│   │   ├── 1.png
│   │   └── 2.png
│   ├── js
│   │   ├── app.js
│   │   └── math.js
│   └── sheet
│       ├── css.css //
│       └── less.less //
├── view
│   └── index.html //
└── yarn.lock //

package.json

{
  "name": "sample",
  "version": "1.0.0",
  "private": true,
  "license": "MIT",
  "scripts": {
    "dev": "webpack --config dev-webpack.config.js",
    "build": "webpack --config bulid-webpack.config.js"
  },
  "devDependencies": {
    "autoprefixer": "^9.6.0",
    "clean-webpack-plugin": "^3.0.0",
    "css-loader": "^2.1.1",
    "file-loader": "^4.0.0",
    "html-webpack-plugin": "^3.2.0",
    "less": "^3.9.0",
    "less-loader": "^5.0.0",
    "postcss-loader": "^3.0.0",
    "style-loader": "^0.23.1",
    "url-loader": "^2.0.0",
    "webpack": "^4.33.0",
    "webpack-cli": "^3.3.3"
  },
  "browserslist": [ //支持的浏览器,主流浏览器最后2个版本,用于样式添加厂商前缀
    "last 2 versions"
  ]
}

webapck.config

dev-webpack.config.js     (yarn dev)
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const {CleanWebpackPlugin} = require('clean-webpack-plugin');

module.exports = {
    entry: {
        app: './src/js/app.js'
    },
    output: {
        filename: "[hash:8]--[name].js",
        path: path.resolve(__dirname, 'dist'),
        // publicPath: "https://192.168.1.106:6655" //用于CND之类
    },
    mode: "development",
    devtool: "cheap-module-eval-source-map",
    module: {
        rules: [
            {
                test: /.css$/,
                use: [
                    'style-loader',
                    {
                        loader: "css-loader",
                        options: {
                            importLoaders: 1
                        }
                    },
                    'postcss-loader'
                ]
            },
            {
                test: /\.less$/,
                use: [
                    'style-loader',
                    {
                        loader: "css-loader",
                        options: {
                            modules: true,
                            importLoaders: 2
                        }
                    },
                    'less-loader',
                    "postcss-loader",
                ]
            },
            {
                test: /\.(png|jpg|gif)$/,
                use: {
                    loader: "url-loader",
                    options: {
                        name: '[hash:8]--[name].[ext]',
                        outputPath: 'images',
                        limit: 8 * 1024,
                    }
                }
            },
            {
                test: /\.(eot|svg|ttf|woff|woff2)$/,
                use: {
                    loader: "file-loader",
                    options: {
                        name: '[hash:8]--[name].[ext]',
                    }
                }
            }
        ]
    },
    plugins: [
        new HtmlWebpackPlugin({ //拷贝到输出目录,并注入打包后的js文件
            template: "./view/index.html"
        }),
        new CleanWebpackPlugin(), //清除输出目录中的文件
    ]
};
bulid-webpack.config.js   (yarn build)
const md = require('./dev-webpack.config.js');
const build = { //不一样的就这两个部分
    mode: "production",
    devtool: "cheap-module-source-map",
};
Object.assign(md, build);
module.exports = md;

postcss.config.js

module.exports = {
    plugins: [
        require('autoprefixer') //使用插件autoprefixer, 用于增加厂商前缀
    ],
};

view 下的 index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div style="font-size: 100px; background: coral">
    <i class="iconfont icon-icon-test"></i>
    <i class="iconfont icon-icon-test1"></i>
    <i class="iconfont icon-icon-test2"></i>
</div>
<div id="img1" style="width: 100px; height: 150px; overflow: hidden"></div>
<div id="img2"></div>

<h1 class="at">全局的</h1>
<h1 class="lt">模块化样式测试1(局部样式,代码中添加)</h1>
<div style="height: 200px"></div>
<h1 class="lt">模块化样式测试2(没有在代码中添加类)</h1>
</body>
</html>

样式

css
*{
    padding: 0;
    margin: 0;
}
.at{
    transform: translate(100px, 100px);
    color: aqua;
}
less
.lt{
  transform: translate(unit(100, px), unit(100, px));
  color: chocolate;
}

js

app.js
// 全局样式
import '../sheet/css.css';
import '../fonts/iconfont.css';

// 普通的js导入测试
import math from './math.js';

console.log('add(11, 11): ', math.add(11, 11));
console.log('mul(11, 11): ', math.mul(11, 11));
console.log('sub(110, 11): ', math.sub(110, 11));

// 样式模块化测试
import less from '../sheet/less.less';

window.document.querySelector('.lt').classList.add(less.lt);

// 图片测试 > 8 K
let img = new Image();
img.src = require('../images/1.png');
window.document.querySelector('#img1').appendChild(img);

// 图片测试 < 8 K
img = new Image();
img.src = require('../images/2.png');
window.document.querySelector('#img2').appendChild(img);
math.js
export default {
    sub: function (a, b) {
        return a - b;
    },
    add: function (a, b) {
        return a + b;
    },
    mul: function (a, b) {
        return a * b;
    }
}

fonts目录: Iconfont-阿里巴巴矢量图标库 (https://www.iconfont.cn/)上下载的文件

dist 目录:打包后的文件结构

注:yarn dev 和 yarn build 打包后的文件有点不同(后者有.map文件)

demo_static_resrouce的更多相关文章

随机推荐

  1. Solidworks如何另存为和打开OBJ文件

    1 点击工具-插件,勾选ScanTo3D(最好后面的启动也勾选上,否则下次启动将不会默认自动启动这个插件,还需要再做一次才能打开或者另存为OBJ)   2 注意打开零件图的方式,你不能直接打开Soli ...

  2. erlang二进制数据垃圾回收机制

    erlang二进制数据在内存中有两种存在形式,当数据大小不到 64 bytes,就直接存在进程堆内.假设超过了64 bytes.就被保存到进程外的共享堆里,能够给节点内全部进程共享. erlang有两 ...

  3. 表格属就用treegrid

    http://maxazan.github.io/jquery-treegrid/ 如果想ajax后台动态添加表格数据然后再形成treegrid,那么可以通过后台给一个对应行索引的数组, 进行动态改变 ...

  4. AD10 库下载地址

    http://wiki.altium.com/display/ADOH/Download+Libraries 最新更新库地址: http://designcontent.live.altium.com ...

  5. Coursera Algorithms week4 基础标签表 练习测验:Check if a binary tree is a BST

    题目原文: Given a binary tree where each 

  6. tinymce 富文本编辑器 编写资料

    tinymce官方文档: 粘贴图片插件 博客搬运地址 使用Blob获取图片并二进制显示实例页面 tinymce自动调整插件 是时候掌握一个富文本编辑器了——TinyMCE(1) XMLHttpRequ ...

  7. assistant: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.15' not found (required by

    [oracle@oracledb button]$ assistantassistant: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.15' no ...

  8. JavaScript正则表达式(一)-常用方法

    公司之前有个胖女孩说你竟然会正则? 其实正则没那么难:今天我们说说他常用的几个API. 在讲方法之前, 我们先对正则表达式做一个基本的了解: 1.正则表达式定义使用单个字符串来描述.匹配一系列符合某个 ...

  9. 【题解】晋升者计数 Promotion Counting [USACO 17 JAN] [P3605]

    [题解]晋升者计数 Promotion Counting [USACO 17 JAN] [P3605] 奶牛们又一次试图创建一家创业公司,还是没有从过去的经验中吸取教训.!牛是可怕的管理者! [题目描 ...

  10. 【POJ1845】Sumdiv(数论/约数和定理/等比数列二分求和)

    题目: POJ1845 分析: 首先用线性筛把\(A\)分解质因数,得到: \[A=p_1^{a_1}*p_2^{a_2}...*p_n^{a_n} (p_i是质数且a_i>0) \] 则显然\ ...