博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
更优雅的使用 Parcel 进行前端项目的打包
阅读量:6116 次
发布时间:2019-06-21

本文共 2752 字,大约阅读时间需要 9 分钟。

Parcel 有着开箱即用的特性, 为我们初始化工程省却了许多时间, 但是零配置的特性导致我们比较不方便进行一些预处理, 这篇文章就带领读者解决一些我们常会遇到的一些问题. 只需要很简单的添加几个参数,就可以满足我们大部分的特殊情况.

在去年, Parcel 没有支持 SourceMap 的特性, 导致于无法进行断点调试, 从而很多团队没有在生产中使用 Parcel, 现在 Parcel 已经支持 SourceMap 的特性, 再加上可以很方便的编写插件去填补一些自定义的功能, 所以 Parcel 我认为已经可以在新项目的生产中投入使用了.

本文作者简单的编写了一个 parcel-plugin-change-file 插件示例, 来满足下面的功能, 具体使用请继续阅读文章内容.

本文不会对 Parcel 的基础使用再多做解释, 如果您还没有接触过 Parcel ,请先去了解:

如何跳过不需要打包的文件?

如果我们使用 parcel index.html 命令, Parcel 会自动识别html中的引用,如果是http://就不会进行打包处理, 如果是本地文件,就会识别成Assets对象,进行打包.

如果我们需要跳过对本地文件的打包, 我们可以使用 parcel-plugin-change-file 插件

$ yarn add -D parcel-plugin-change-file复制代码

在 index.html中添加 <!--[ your-code ]--> , 注意这里有两个中括号.

  
复制代码

当项目编译结束之后, 该插件会把 <!--[ your-code ]--> 的注释内容打开,从而跳过 Parcel 的打包检测.

  复制代码

如何对html进行修改?

例如, 我们尝试根据 package.json 中的信息修改 index.htmltitle

在项目跟路径创建 parcel-plugin-change-file.js 文件

const package = require('./package.json')module.exports = {  html: [package.name],};复制代码

src/index.html 中添加 <!-- parcel-plugin-change-file-i --> , 其中 i 对应之前 html 对象中的数组下标, 这里我们只有一个, 所以用 0

<!-- parcel-plugin-change-file-0 -->
复制代码

当项目编译结束之后, 该插件会把 package.json 中的 name 信息插入到 title

  Parcel优雅配置复制代码

如何在parcel打包结束之后拷贝一些文件到打包目录?

例如, 某些情况, 我们不需要 Parcel 帮我们处理 png 图片, 我们希望直接使用图片路径:

class Banner extends React.Componet {  render(){    return 
}}复制代码

那我们就需要在打包之后再把图片拷贝到相应的路径.

还是确保parcel-plugin-change-file 已被安装, 然后在项目跟路径创建parcel-plugin-change-file.js

module.exports = {  copy: ['src/assets', 'src/documents'],};复制代码

正常执行 Parcel 打包脚本, 就会把 src/assetssrc/documents子内容拷贝到打包输出的跟路径

$ parcel src/index.html复制代码

如何达到和 webpack.DllPlugin 一样的预先编译的效果呢?

Webpack 的 DllPlugin 插件可以把一些不常进行修改的库提前编译成一个文件, 然后在项目里引用, 经过配置webpack不会再次编译这些已经编译过的文件.这样可以大大的加速平时编译的时间. 从而赶上 Parcel 的打包速度.

而在 Parcel 中,也可以可以把一些不常进行修改的库提前编译成一个文件, 这样可以在 Parcel 原本就快速的编译前提下再减去绝大部分的编译内容, 从而极大的加速平时编译的时间, 不过就只能使用全局对象引用了.

在Parcel项目中, 是可以使用全局对象的, 例如我们在html中引入一个lodash:

    复制代码

此时, 在项目中不需要import _ from 'lodash', 可以识别全局_对象的

console.log(_.map)  //可以打印出 _.map 方法复制代码

有了以上知识点,我们可以这样做:

  1. 创建一个预先需要打包的文件:
// dll/default.js// 假设这些库是自己编写的库, 需要在预编译, 并且在全局引用import _ from 'lodash';import Immutable from 'immutable';// 暴露到全局对象中window['_'] = _;window['Immutable'] = Immutable;复制代码
  1. 使用Parcel进行打包, 其中changeFile=false 是不使用 parcel-plugin-change-file 插件:
$ changeFile=false parcel build dll/default.js -d src/dll -o defalut.min.js复制代码

以上 default.min.js 已经创建好了, 接下来是在平时 Parcel 的项目中使用它

  1. 我们需要在 src/index.html 里引入 src/dll/default.min.js
    
复制代码
  1. 创建parcel-plugin-change-file.js
module.exports = {  copy: ['src/dll'],};复制代码
  1. 大功告成,可以在项目里直接使用之前 default.min.js 中暴露在 window 下的全局对象
// src/index.js_.map(_.range(500), v=>{  console.log(`hello:${v}`);})复制代码
  1. 如果需要有提示, 需要编写 .d.ts 文件, 然后在项目中引入

这一块知识点请查阅

/// 
复制代码

启动项目:

$ parcel src/index.html复制代码

最后, 如果这篇文章有帮到你, 欢迎 Star:

转载地址:http://lovka.baihongyu.com/

你可能感兴趣的文章
Android扩展 - 拍照篇(Camera)
查看>>
JAVA数组的定义及用法
查看>>
充分利用HTML标签元素 – 简单的xtyle前端框架
查看>>
设计模式(十一):FACADE外观模式 -- 结构型模式
查看>>
iOS xcodebuile 自动编译打包ipa
查看>>
程序员眼中的 SQL Server-执行计划教会我如何创建索引?
查看>>
【BZOJ】1624: [Usaco2008 Open] Clear And Present Danger 寻宝之路(floyd)
查看>>
cmake总结
查看>>
数据加密插件
查看>>
linux后台运行程序
查看>>
win7 vs2012/2013 编译boost 1.55
查看>>
IIS7如何显示详细错误信息
查看>>
ViewPager切换动画PageTransformer使用
查看>>
coco2d-x 基于视口的地图设计
查看>>
C++文件读写详解(ofstream,ifstream,fstream)
查看>>
Android打包常见错误之Export aborted because fatal lint errors were found
查看>>
Tar打包、压缩与解压缩到指定目录的方法
查看>>
新手如何学习 jQuery?
查看>>
配置spring上下文
查看>>
Python异步IO --- 轻松管理10k+并发连接
查看>>