Skip to main content Skip to docs navigation

Bootstrap and Parcel

关于如何使用Parcel在项目中包含和捆绑Bootstrap的CSS和JavaScript的官方指南。

想跳到最后吗twbs/examples存储库下载本指南的源代码和工作演示。 你也可以在StackBlitz中打开示例但不要运行它,因为Parcel目前不受支持。

安装程序

我们正在用Bootstrap从头开始构建一个Parcel项目,所以在我们真正开始之前,有一些先决条件和前期步骤。 本指南要求你已安装Node.js并熟悉终端。

  1. 创建一个项目文件夹并设置npm我们将创建 my-project 文件夹,并使用-y参数初始化npm,以避免它向我们提出所有交互式问题。

    mkdir my-project && cd my-project
    npm init -y
    
  2. 安装Parcel与我们的Webpack指南不同,这里只有一个构建工具依赖项。 Parcel将在检测到语言转换器时自动安装它们(如Sass)。 我们使用--save-dev来表示这种依赖关系仅用于开发,而不用于生产。

    npm i --save-dev parcel
    
  3. **安装Bootstrap。**现在我们可以安装Bootstrap了。 我们还将安装Popper,因为我们的下拉菜单、弹出菜单和工具提示的定位都依赖于它。 如果你不打算使用这些组件,可以在此处省略Popper。

    npm i --save bootstrap @popperjs/core
    

既然我们已经安装了所有必要的依赖项,我们就可以开始创建项目文件和导入Bootstrap了。

项目结构

我们已经创建了 my-project 文件夹并初始化了npm。 现在,我们还将创建src文件夹、样式表和JavaScript文件,以完善项目结构。 从 my-project 运行以下操作,或手动创建如下所示的文件夹和文件结构。

mkdir {src,src/js,src/scss}
touch src/index.html src/js/main.js src/scss/styles.scss

当你完成后,你的整个项目应该是这样的:

my-project/
├── src/
│   ├── js/
│   │   └── main.js
│   ├── scss/
│   │   └── styles.scss
│   └── index.html
├── package-lock.json
└── package.json

在这一点上,一切都在正确的位置,但Parcel需要一个HTML页面和npm脚本来启动我们的服务器。

配置Parcel

安装了依赖项,我们的项目文件夹可以开始编码,现在我们可以配置Parcel并在本地运行我们的项目。 Parcel本身在设计上不需要配置文件,但我们确实需要一个npm脚本和一个HTML文件来启动我们的服务器。

  1. 填写src/index.html文件Parcel需要一个页面来渲染,所以我们使用index.html页面来设置一些基本的html,包括CSS和JavaScript文件。

    <!doctype html>
    <html lang="en">
      <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title>Bootstrap w/ Parcel</title>
        <link rel="stylesheet" href="scss/styles.scss">
        <script type="module" src="js/main.js"></script>
      </head>
      <body>
        <div class="container py-4 px-3 mx-auto">
          <h1>Hello, Bootstrap and Parcel!</h1>
          <button class="btn btn-primary">Primary button</button>
        </div>
      </body>
    </html>
    

我们在这里用div class="container"<button>包含了一些Bootstrap样式,这样我们就可以看到Parcel加载Bootstrap的CSS时的情况。

Parcel将自动检测到我们正在使用Sass,并安装Sass Parcel插件支持它。 但是,如果你愿意,也可以手动运行npm i --save-dev @parcel/transformer-sass

  1. 添加Parcel npm脚本打开package.json并将以下start脚本添加到scripts对象中。 我们将使用此脚本启动Parcel开发服务器,并在将创建的HTML文件编译到dist目录后呈现该文件。

    {
       // ...
       "scripts": {
         "start": "parcel serve src/index.html --public-url / --dist-dir dist",
         "test": "echo \"Error: no test specified\" && exit 1"
       },
       // ...
    }
    
  2. 最后,我们可以启动Parcel在终端的my-project文件夹中,运行新添加的npm脚本:

    npm start
    
    Parcel dev server running

在本指南的下一节也是最后一节中,我们将导入Bootstrap的所有CSS和JavaScript。

导入Bootstrap

将Bootstrap导入Parcel需要两个导入,一个导入到我们的style.scs,另一个导入我们的main.js

  1. 导入Bootstrap的CSS将以下内容添加到src/scss/styles.scss以导入Bootstrap的所有源Sass。

    // Import all of Bootstrap's CSS
    @import "bootstrap/scss/bootstrap";
    

如果需要,你也可以单独导入我们的样式表。阅读我们的Sass导入文档了解详细信息

  1. 导入Bootstrap的JS将以下内容添加到src/js/main.js以导入Bootstrap的所有js。 Popper将通过Bootstrap自动导入。

    // Import all of Bootstrap's JS
    import * as bootstrap from 'bootstrap'
    

你还可以根据需要单独导入JavaScript插件,以降低捆绑包大小:

import Alert from 'bootstrap/js/dist/alert'

// or, specify which plugins you need:
import { Tooltip, Toast, Popover } from 'bootstrap'

Read our JavaScript docs for more information on how to use Bootstrap’s plugins.

  1. 大功告成!🎉Bootstrap的源代码Sass和JS已经完全加载,你的本地开发服务器现在应该是这样的。

    Parcel dev server running with Bootstrap

现在,你可以开始添加你想要使用的任何引导组件。 一定要查看完整的Parcel示例项目了解如何包括额外的自定义Sass,并通过只导入Bootstrap的CSS和JS中你需要的部分来优化你的构建。


See something wrong or out of date here? Please open an issue on GitHub. Need help troubleshooting? Search or start a discussion on GitHub.