# w5-test **Repository Path**: kgm0515/w5-test ## Basic Information - **Project Name**: w5-test - **Description**: 测试webpack5 - **Primary Language**: JavaScript - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2021-05-10 - **Last Updated**: 2021-07-26 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # w5-test #### 文档地址 > https://webpack.docschina.org/guides/environment-variables/ #### 介绍 测试 webpack5 #### 软件架构 软件架构说明 #### 安装教程 1. xxxx 2. xxxx 3. xxxx #### 使用说明 1. xxxx 2. xxxx 3. xxxx #### 参与贡献 1. Fork 本仓库 2. 新建 Feat_xxx 分支 3. 提交代码 4. 新建 Pull Request #### 特技 1. 使用 Readme_XXX.md 来支持不同的语言,例如 Readme_en.md, Readme_zh.md 2. Gitee 官方博客 [blog.gitee.com](https://blog.gitee.com) 3. 你可以 [https://gitee.com/explore](https://gitee.com/explore) 这个地址来了解 Gitee 上的优秀开源项目 4. [GVP](https://gitee.com/gvp) 全称是 Gitee 最有价值开源项目,是综合评定出的优秀开源项目 5. Gitee 官方提供的使用手册 [https://gitee.com/help](https://gitee.com/help) 6. Gitee 封面人物是一档用来展示 Gitee 会员风采的栏目 [https://gitee.com/gitee-stars/](https://gitee.com/gitee-stars/) #### loader ##### 编写babel-loader cnpm i loader-utils -D cnpm i @babel/preset-env @babel/core -D ##### 编写banner-loader 给每个源代码添加一个头部注释 cnpm i schema-utils -D ##### 编写less-loader cnpm i less -D ##### 编写css-loader cnpm i file-loader url-loader postcss -D cnpm i css-selector-tokenizer -D #### 编写url-loader cnpm i mime -D // 获取文件内容类型 #### 编写sprite-loader 多张小图合成雪碧图 cnpm i -D spritesmith [spritesmith文档](https://www.npmjs.com/package/spritesmith) [postcss文档](https://api.postcss.org/) #### 编写px2rem-loader 遍历所有的值,如果是以px结尾的后缀,经过计算改为rem ### 编写插件plugin #### 打包插件ZipPlugin npm i -D jszip [参考文档](https://www.npmjs.com/package/jszip) ### 自己写一个webpack #### 安装插件 - babylon // babel中解析js成语法树 - babel-types // 包含很多方法能手动构建语法树,判断节点是否时想要的类型 - babel-generator // 把语法树转化为代码 - babel-traverse // 维护整个树的状态,能添加删除修改节点 - cnpm i babylon babel-types babel-generator babel-traverse -D - cnpm i ejs -D - 相关查看ast的网站:astexplorer.net