【Vue.js 入门笔记】Webpack 入门

Webpack 是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源。

从图中我们可以看出,Webpack 可以将多种静态资源 js、css、less 转换成一个静态文件,减少了页面的请求。

接下来我们简单为大家介绍 Webpack 的安装与使用。

安装 Webpack

在安装 Webpack 前,你本地环境需要支持 node.js。

复制代码
npm install webpack -g

创建项目

·接下来我们创建一个目录 contents:

复制代码
mkdir contents

在 app 目录下添加 index.js \ index.html 文件

接下来我们使用 webpack 命令来打包:

复制代码
webpack index.js bundle.js

成功后的图片

打开index.html后。出现结果如下图所示

创建第二个样式文件

(略)。

代码尝试走了但是没走通

配置loader

Webpack 本身只能处理 JavaScript 模块,如果要处理其他类型的文件,就需要使用 loader 进行转换。

所以如果我们需要在应用中添加 css 文件,就需要使用到 css-loader 和 style-loader。

css-loader 会遍历 CSS 文件,然后找到 url() 表达式然后处理他们,style-loader 会把原来的 CSS 代码插入页面中的一个 style 标签中。

接下来我们使用以下命令来安装 css-loader 和 style-loader(全局安装需要参数 -g)。

执行以上命令后,会再当前目录生成 node_modules 目录,它就是 css-loader 和 style-loader 的安装目录。

接下来创建一个 style.css 文件,代码如下:

复制代码
body {
    background: yellow;
}



配置plugin

插件在 webpack 的配置信息 plugins 选项中指定,用于完成一些 loader 不能完成的工作。

webpack 自带一些插件,可以通过 npm 安装一些插件。

使用内置插件需要通过以下命令来安装:

npm install webpack --save-dev

比如我们可以安装内置的 BannerPlugin 插件,用于在文件头部输出一些注释信息。

一个实例

下面是一个小型项目的Webpack配置文件

复制代码
const path = require('path'); // 引入path模块
const webpack = require('webpack'); // 引入webpack
const HtmlWebpackPlugin = require('html-webpack-plugin'); // 引入html-webpack-plugin插件
const ExtractTextPlugin = require('extract-text-webpack-plugin'); // 引入css分离插件
const { devtools } = require('vue');
const { entry, output } = require('../webpack.config.cjs');
const { Plugin } = require('webpack');

module.exports = { 
    devtools:'eval-source-map',
    entry:path.join(__dirname,'../src/main.js'),
    output:{ 
        path:path.join(__dirname,'../dist'),
        filename:'bundle.js'
    },

    devServer:{
        //静态资源根目录
        contentBase:'./static',
        historyApiFallback: true,
        inline:true,
        compress:true,
        port:8080,
        hot:true
    },

    module:{
        rules:[
            {
                test:/\.html$/,
                use:'html-loader'
            },
            {
                test:/\.css$/,
                use: ExtractTextPlugin.extract({
                    fallback: "style-loader",
                    use: "css-loader"
                })
            },
            {
                test:/\.js$/,
                exclude: /node_modules/,
                use:{
                    loader:'babel-loader',
                }
            },
            {
                test:/\.(scss|less)$/,
                use: ExtractTextPlugin.extract({
                    fallback: "style-loader",
                    use: [
                        {
                            loader: "css-loader",
                            options: {
                                url: false,
                                minimize: true,
                                sourceMap: true
                            }
                        },
                        {
                            loader:'sass-loader',
                            options:{
                                sourceMap:true
                            }
                        },
                    ]
                })
            },
            {
                test:/\.(woff2|eot|gttf|otf|svg)$/,
                use:{
                    loader:'file-loader'
                },
            },
            {
                test:/\.(png|jpg|gif)$/,
                use:{
                    loader:'url-loader',
                    options:{
                        limit:8192
                    }
                }
            }

        ]
    },

    plugins:[
        new webpack.HotModuleReplacementPlugin(),

        new HtmlWebpackPlugin({
            
            title:'vue-webpack-demo', 
            filename:'index.html',
            template:'./src/index.html',
            favicon:'./src/favicon.ico',
            inject:true,
            hash:true
        }),

        // 引入以作为其他插件的依赖
        new webpack.ProvidePlugin({
            $:'jquery',
            jQuery:'jquery',
            'window.jQuery':'jquery'
        }),

        new ExtractTextPlugin('style.css'), // 将css提取成单独的文件
    ]
};

参考链接

  1. https://www.cnblogs.com/ljbguanli/p/19243924
  2. https://www.runoob.com/w3cnote/webpack-tutorial.html
相关推荐
徐小夕3 小时前
被CRUD拖垮的第5年,我用Cursor 一周"复仇":pxcharts-vue开源,一个全栈老兵的AI编程账本
前端·vue.js·github
睡不着的可乐6 小时前
vue2 和 vue3自定义指令有什么区别,都是怎么实现和使用一个指令
前端·vue.js
想努力找到前端实习的呆呆鸟6 小时前
网易云桌面端--精选歌单布局思路记录
前端·javascript·vue.js
OpenTiny社区7 小时前
TinyRobot:基于 OpenTiny Design 的企业级 AI 交互组件框架
前端·vue.js·ai编程
踩着两条虫7 小时前
AI 驱动的 Vue3 应用开发平台 深入探究(三):核心概念之引擎架构与生命周期
前端·vue.js·ai编程
_Eleven7 小时前
Tiptap 完全使用指南
前端·vue.js·github
jeff渣渣富8 小时前
Taro 小程序构建自动化:手写插件实现图片自动上传 OSS 并智能缓存
前端·webpack
踩着两条虫10 小时前
AI 驱动的 Vue3 应用开发平台 深入探究(二):核心概念之DSL模式与数据模型
前端·vue.js·ai编程
SuperEugene12 小时前
Vite 实战教程:alias/env/proxy 配置 + 打包优化避坑|Vue 工程化必备
前端·javascript·vue.js