Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >怎么用webpack搭建前端环境?

怎么用webpack搭建前端环境?

作者头像
江一铭
发布于 2022-06-16 00:59:21
发布于 2022-06-16 00:59:21
1.2K00
代码可运行
举报
文章被收录于专栏:技术社区技术社区
运行总次数:0
代码可运行

一、前端构建工具

  1. grunt
  2. gulp
  3. webpack(主流,https://webpack.js.org/)
  4. Fis3(百度)

二、webpack是什么

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
webpack 是一个现代 JavaScript 应用程序的静态模块打包器

webpack稳定版本:v4.44

三、如何使用webpack搭建前端环境

  1. 安装node.js( v12.x)
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
注意:如果npm安装一些包由于网速原因,安装慢切换一下镜像源

改成淘宝镜像:
npm config set registry https://registry.npm.taobao.org

查看是否更改过来:
npm config list回车

2.创建项目目录并初始化package.json

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
默认创建package.json文件

npm init -y

3.安装webpack和webpack-cli

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
npm install webpack webpack-cli --save-dev

简写:
npm i webpack webpack-cli -D

4.运行webpack测试

CommonJS规范:基于服务端模块化规范,node产出

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
抛出:modules.exports
引入:require

ES6 module:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import xxx from ''
export default {}

5.webpack支持的文件类型

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
默认只支持JS和json文件的引入

注意:如果在JS中要引入其他文件类型:.css,.png,字体文件或其他做任意文件类型,解析时都需求安装合适的loader来进行解析处理

6.webpack配置文件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
默认配置文件名:webpack.config.js

如果想运行其他配置文件
webpack --config webpack.dev.config.js

配置文件是webpack的核心,所有的loader和插件环境,运行环境配置都在配置文件中配置使用

例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//引入webpack,主要用于对webpack内置插件调用时使用
const webpack = require('webpack')
//引入path,对路径进行处理
const path = require('path')

//创建一个配置对象
const config = {
    //配置入口
    entry: './src/main.js',
    //配置出口
    output: {
        //出口路径
        path:path.resolve(__dirname,'dist'),
        //出口文件名
        filename:'bundle.js'
    }

}

module.exports = config;

7.配置各种loader(文件解析器)

  • 解析css的loader
  • 解析图片 file-loader,url-loader
  • 解析ES6/7/8/9/10… babel
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
第一步:npm install --save-dev babel-loader @babel/core @babel/preset-env 
第二步:在项目根目录下创建一个.babelrc文件,并写入
{
  "presets": ["@babel/preset-env"]
}
第三步:配置loader
module: {
  rules: [
    { test: /\.js$/, exclude: /node_modules/, loader: "babel-loader" }
  ]
}
  1. 自动清理文件
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
npm install clean-webpack-plugin --save-dev

引入
const { CleanWebpackPlugin } = require('clean-webpack-plugin');

使用:

//创建一个配置对象
const config = {
   .....,
    plugins: [
        new CleanWebpackPlugin()
    ]

}
  1. 自动注入html
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
npm install --save-dev html-webpack-plugin


//创建一个配置对象
const config = {
    ....,
    plugins: [
        //自动清理
        new CleanWebpackPlugin(),
        //自动注入html
        new HtmlWebpackPlugin({
            template: './src/index.html',
            filename:'home.html'
        }),
    ]

}

10.运行环境

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
webpack-dev-server

配置文件中:
 devServer: {
        contentBase: path.join(__dirname, "dist"),  //监听运行目录
        port: 9999,  //运行端口号
        hot:true  //热更新
    }

11.webpack核心概念:

  • 入口:entry:指向项目执行的主入口
  • 出口:output 构建输出的文件路径和文件名
  • 加载器:loader 转换webpack不识别的文件(资源)类型
  • 插件:plugins 为了扩展webpack的功能,例如:清理文件,自动注入Html
  • 模式:mode 切换开发环境(development)还是线上(production)环境

12.与vue集成

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
vue-loader:解析vue文件
vue-template-compiler

安装:npm install vue-loader vue-template-compiler -D
配置webpack文件: {test:/\.vue$/,use:['vue-loader']},

实例化vueLoaderPlugin插件
const { VueLoaderPlugin }=require('vue-loader')
添加插件实例化:
 },
    plugins: [
        new VueLoaderPlugin()
    ]

13、与less集成

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
安装:npm install less-loader less -D
配置:
 module: {
        rules: [
            {test:/\.less$/,use:['style-loader','css-loader','less-loader']},
        ]
    },

14.与sass集成

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
安装:npm install sass-loader node-sass -D
配置:
 module: {
        rules: [
            {test:/\.(scss|sass)$/,use:['style-loader','css-loader','sass-loader']},
        ]
    },
sass常用语法:https://www.cnblogs.com/chyingp/p/sass-basic.html

15.与vue-router

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
安装:npm install vue-router -D

15.与vuex的集成

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
安装:npm install vuex -D
注意:没有要解析的loader
You may need an appropriate loader to handle this file type

16.完整的webpack.config.js文件内容如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//引入webpack,主要用于对webpack内置插件调用时使用
const webpack = require('webpack')
    //引入path,对路径进行处理
const path = require('path')
    //引入清理插件
const { CleanWebpackPlugin } = require('clean-webpack-plugin');
//引入htmlwebpckPlugin插件
const HtmlWebpackPlugin = require('html-webpack-plugin')
    //引入VueLoaderPlugin
const { VueLoaderPlugin } = require('vue-loader')

//创建一个配置对象
const config = {
    //线上线下环境
    mode: 'production',
    //配置入口
    entry: './src/main.js',
    //配置出口
    output: {
        //出口路径
        path: path.resolve(__dirname, 'dist'),
        //出口文件名
        filename: 'bundle.js'
    },
    module: {
        rules: [
            // {test:/\.要解析的文件类型$/,use:['要使用的loader']},
            { test: /\.css$/, use: ['style-loader', 'css-loader'] },
            { test: /\.less$/, use: ['style-loader', 'css-loader', 'less-loader'] },
            { test: /\.(scss|sass)$/, use: ['style-loader', 'css-loader', 'sass-loader'] },
            { test: /\.css$/, use: ['style-loader', 'css-loader'] },
            { test: /\.vue$/, use: ['vue-loader'] },
            { test: /\.(png|jpg|jpeg|gif)$/, use: ['file-loader'] },
            { test: /\.js$/, exclude: /node_modules/, loader: "babel-loader" }
        ]
    },
    //配置缺少文件类型
    resolve: {
        extensions: ['.js', '.json', '.vue']
    },
    plugins: [
        new CleanWebpackPlugin(),
        new HtmlWebpackPlugin({
            template: './src/index.html',
            filename: 'index.html'
        }),
        new webpack.BannerPlugin('项目的入口'),
        new VueLoaderPlugin()
    ],
    devServer: {
        contentBase: path.join(__dirname, "dist"),
        port: 9999,
        hot: true
    }

}

module.exports = config;
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-08-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
webpack构建自定义vue应用
相比较react,vue所需要的插件要少得多,我们知道在vue中,大多数是以.vue的模版组件,因此关键是我们可以用webpack的相关loader能够解析.vue文件即可,在vue项目中解析单文件组件,热加载,css作用域等全部依赖于这个插件vue-loader[1],因此vue-loader算是vue工程化中必不可少的一个插件。
Maic
2022/07/28
5250
webpack构建自定义vue应用
59.Vue 使用webpack构建vue项目
在前面的篇章中,已经说明了 webpack4 的基本使用,那么本章节开始在 webpack4 中构建vue项目,同时对比看看这种构建方式,与在网页script导入 vue.js 中的区别。
Devops海洋的渔夫
2020/08/20
2.7K0
59.Vue 使用webpack构建vue项目
plugins webpack_webpack实现原理
插件是 webpack 的支柱功能。webpack 自身也是构建于你在 webpack 配置中用到的相同的插件系统之上! 插件目的在于解决 loader 无法实现的其他事。
全栈程序员站长
2022/09/19
4670
Webpack4 搭建 Vue 项目
由于 Parcel 打包工具的影响,webpack4 也追求零配置搭建项目。而前阵子出现的 vue-cli 3.0也是基于 webpack4 零配置的思想创建的。对于一些习惯webpack3 的开发者难免有些不习惯。本文就带你绕过 vue-cli,用 webpack4 一步步搭建 vue 项目。
小皮咖
2019/11/05
1.1K0
webpack 构建脚手架
本文记录 webpack 的安装和使用,并且使用 webpack 搭建 vue 简易脚手架的过程
很酷的站长
2022/12/28
4430
webpack 构建脚手架
webpack 入门教程
本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。
老马
2018/08/20
4K0
webpack 入门教程
深入浅出webpack的最佳实践!
导语 | 本文推选自腾讯云开发者社区-【技思广益 · 腾讯技术人原创集】专栏。该专栏是腾讯云开发者社区为腾讯技术人与广泛开发者打造的分享交流窗口。栏目邀约腾讯技术人分享原创的技术积淀,与广泛开发者互启迪共成长。本文作者是腾讯云前端开发Jou。 自从加入腾讯,作者便一直在使用webpack,因此,本文主要整理一下webpack相关的知识点,由浅入深,后续会一直更新分享,以便对此方面感兴趣的开发者们提供一些经验和帮助。欢迎点击文末「阅读原文」访问腾讯云开发者社区,查看作者作品~ 核心概念 (一)Module
腾讯云开发者
2022/08/31
6850
深入浅出webpack的最佳实践!
Webpack4 新手完全攻略
为了优化前端工程, 我们通常会将静态文件压缩,减少带宽占用; 将静态文件合并,减少http请求, webpack可以轻易实现静态文件的压缩合并以及打包的功能, 除此之外, webpack还支持众多的loader插件, 通过loader插件可实现众多类型(如vue, less, jpg, css)资源的打包 webpack的文档写的相当出色, 为了方便读者学习, 下面每一类配置的注释里, 都附上了参考的原文档地址, 如果以后配置更新了,也方便查看更新的文档 如果不想自己配置, 可以直接拷贝最后的配置文档到自己
zhaoolee
2018/04/28
9860
Webpack4 新手完全攻略
​(非软文)Webpack从入门到实战搭建Vue脚手架(一万字总结)
安装依赖包 (-D 将依赖记录成开发依赖, 只是开发中需要用的依赖, 实际上线不需要的)
Vam的金豆之路
2021/12/01
1.3K0
入职第三天:vue-loader在项目中是如何配置的
这是我入职第三天的故事,在写这篇文章之前,先来看看咱们今天要讲的主角——vue-loader,你对它了解多少?
闰土大叔
2018/07/24
9970
入职第三天:vue-loader在项目中是如何配置的
webpack配置完全指南
首先webpack是一个静态模块打包器,所谓的静态模块,包括脚本、样式表和图片等等;webpack打包时首先遍历所有的静态资源,根据资源的引用,构建出一个依赖关系图,然后再将模块划分,打包出一个或多个bundle。再次白piao一下官网的图,生动的描述了这个过程:
gogo2027
2022/10/03
1.3K0
从0到1 Webpack搭建Vue3开发、生产环境
起步 创建项目目录 mkdir webpack-vue3-demo 初始化 package.json npm init -y 参考文档 安装 webpack webpack-cli webpack-dev-server webpack-merge npm install webpack webpack-cli webpack-dev-server webpack-merge --save-dev 创建配置文件 mkdir build cd build touch webpack.b
peng_tianyu
2022/12/15
1.1K0
从0到1 Webpack搭建Vue3开发、生产环境
【Vue_05】前端工程化
一、ES6的模块化 1. ES6模块化规范 每个 js 文件都是一个独立的模块 导入模块成员使用 import 关键字 暴露模块成员使用 export 关键字 2. 基本语法 发使用 ex
用户8250147
2021/02/04
5540
【Vue_05】前端工程化
用 webpack 4.0 撸单页/多页脚手架 (jquery, react, vue, typescript)
首先来简单介绍一下webpack:现代 JavaScript 应用程序的静态模块打包工具。当 webpack 处理应用程序时,它会在内部构建一个会映射项目所需的每个模块 的依赖图(dependency graph),并生成一个或多个 bundle。webpack4.0出现之后,我们可以不用再引入一个配置文件来打包项目,并且它仍然有着很高的可配置性,可以很好满足我们的需求。 在开始正文之前,首先先来看看我们要实现的成果:
徐小夕
2019/08/08
2.4K0
用 webpack 4.0 撸单页/多页脚手架 (jquery, react, vue, typescript)
webpack打包工具入门
webpack 是一个模块打包器。webpack 的主要目标是将 JavaScript 文件打包在一起,打包后的文件用于在浏览器中使用
羽翰尘
2019/11/20
5230
vue3+webpack项目搭建实验
在 postcss.config.js中配置 autoprefixer用于给css加前缀, cssnano用于压缩优化css
治电小白菜
2020/08/25
2.7K2
webpack从零搭建开发环境
为了方便也可以这么写,使用 npm run 命令这个命令执行的时候默认会把 node_modules 的.bin 文件放到全局上,执行之后销毁npm run buildnpm run dev
小丑同学
2020/09/21
1.3K0
Vue 3 和 Webpack 5 来了,手动搭建的知识该更新了
前言 想必绝大多数用 Vue 开发过项目的同学,或多或少会有以下两种情况: 用 Vue CLI 工具去搭建一个项目。 在领导或同事搭建好的项目基础上做业务。 长此以往,会导致你对整个项目的把控度越来
Nealyang
2021/02/01
2K0
Vue 3 和 Webpack 5 来了,手动搭建的知识该更新了
webpack超详细教程!入门一篇就够了
webpack 是前端的一个项目构建工具,它是基于 Node.js 开发出来的一个前端工具;
beifengtz
2019/08/26
9.9K0
webpack超详细教程!入门一篇就够了
用Single-spa 创建基于 React 和 Vue 的微型前端
它使你可以在单页应用中使用多个框架,这样就可以按功能拆分代码,并 能使 Angular、React、Vue.js 程序一起运行。
疯狂的技术宅
2020/10/22
1.8K0
用Single-spa 创建基于 React 和 Vue 的微型前端
相关推荐
webpack构建自定义vue应用
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验