博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
从零开始搭建一个简单的基于webpack的vue开发环境
阅读量:6265 次
发布时间:2019-06-22

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

都8102年了,现在还来谈webpack的配置,额,是有点晚了。而且,基于vue-cli或者create-react-app生成的项目,也已经一键为我们配置好了webpack,看起来似乎并不需要我们深入了解。

不过,为了学习和理解webpack解决了前端的哪些痛点,还是有必要从零开始自己搭建一个简单的开发环境。本文的webpack配置参考了vue-cli提供webpack-simple模板,这也是vue-cli里面最简单的一个webpack配置,非常适合从零开始学习。

注: 本文webpack基于3.10.0

安装webpack

npm i webpack -g复制代码

项目初始化

新建一个文件夹vue-webpack-simple

新建package.json

npm init -y复制代码

安装vue webpack webpack-dev-server

npm i vue --save复制代码
npm i webpack webpack-dev-server --save-dev复制代码

根目录下新建index.html

    
Document 复制代码

根目录下新建webpack.config.js

var path = require('path');var webpack = require('webpack');module.exports = {};复制代码

新建src文件夹,src文件夹下新建main.js

目前整个项目的结构如下:

js模块化

在ES6出现之前,js是没有统一的模块体系。 服务器端使用CommonJS规范,而浏览器端又有AMD和CMD两种规范

webpack的思想就是一切皆模块,官方推荐使用commonJS规范,这使得我们浏览器端也可以使用commonJS的模块化写法

module.exports = {}复制代码

src目录下新建一个util.js

module.exports = function say() {    console.log('hello world');}复制代码

main.js

var say = require('./util');say();复制代码

修改webpack.config.js

var path = require('path');var webpack = require('webpack');module.exports = {    entry: './src/main.js', // 项目的入口文件,webpack会从main.js开始,把所有依赖的js都加载打包    output: {        path: path.resolve(__dirname, './dist'), // 项目的打包文件路径        publicPath: '/dist/', // 通过devServer访问路径        filename: 'build.js' // 打包后的文件名    },    devServer: {        historyApiFallback: true,        overlay: true    }};复制代码

修改package.josn

"scripts": {    "dev": "webpack-dev-server --open --hot",    "build": "webpack --progress --hide-modules"  },复制代码

注意:webpack-dev-server会自动启动一个静态资源web服务器 --hot参数表示启动热更新

修改index.html,引入打包后的文件

    
Document 复制代码

运行

npm run dev复制代码

可以发现浏览器自动打开的一个页面,查看控制台,有hello world打出

我们随意修改util.js,可以发现浏览器会自动刷新,非常方便。

如果我们希望看打包后的bundle.js文件,运行

npm run build复制代码

可以看到生成了一个dist目录,里面就有打包好后的bundle.js

webpack默认不支持转码es6,但是import export这两个语法却单独支持。所以我们可以改写前面的模块化写法

util.js

export default function say() {    console.log('hello world ');}复制代码

main.js

import say from './util';say();复制代码

引入vue

下面我们来试着引入vue(目前不考虑单文件.vue)

main.js

import Vue from 'vue';var app = new Vue({  el: '#app',  data: {    message: 'Hello Vue!'  }});复制代码

index.html

    
Document
{
{message}}
复制代码

还要注意一点:要修改webpack.config.js文件

var path = require('path');var webpack = require('webpack');module.exports = {    entry: './src/main.js',    output: {        path: path.resolve(__dirname, './dist'),        publicPath: '/dist/',        filename: 'build.js'    },    devServer: {        historyApiFallback: true,        overlay: true    },    resolve: {        alias: {            'vue$': 'vue/dist/vue.esm.js'        }    }};复制代码

重新运行npm run dev,可以看到,页面正常显示了Hello World

引入scss和css

webpack默认只支持js的模块化,如果需要把其他文件也当成模块引入,就需要相对应的loader解析器

npm i node-sass css-loader vue-style-loader sass-loader --save-dev复制代码

webpack.config.js

var path = require('path');var webpack = require('webpack');module.exports = {    entry: './src/main.js',    output: {        path: path.resolve(__dirname, './dist'),        publicPath: '/dist/',        filename: 'build.js'    },    devServer: {        historyApiFallback: true,        overlay: true    },    resolve: {        alias: {            'vue$': 'vue/dist/vue.esm.js'        }    },    module: {        rules: [            {                test: /\.css$/,                use: [                    'vue-style-loader',                    'css-loader'                ],            }        ]    }};复制代码

解释:

{    test: /\.css$/,    use: [        'vue-style-loader',        'css-loader'    ],}复制代码

这段代码意思是:匹配后缀名为css的文件,然后分别用css-loader,vue-style-loader去解析 解析器的执行顺序是从下往上(先css-loader再vue-style-loader)

注意:因为我们这里用vue开发,所以使用vue-style-loader,其他情况使用style-loader

css-loader使得我们可以用模块化的写法引入css,vue-style-loader会将引入的css插入到html页面里的style标签里

要引入scss也是同理的配置写法:

module: {        rules: [            {                test: /\.css$/,                use: [                    'vue-style-loader',                    'css-loader'                ],            },            {                test: /\.scss$/,                use: [                    'vue-style-loader',                    'css-loader',                    'sass-loader'                ],            },            {                test: /\.sass$/,                use: [                    'vue-style-loader',                    'css-loader',                    'sass-loader?indentedSyntax'                ],            }]    }复制代码

我们现在来试下 在src目录下新建style目录,style目录里新建common.scss

body {    background: #fed;}复制代码

main.js

import './style/common.scss';复制代码

发现css样式有用了

使用babel转码

ES6的语法大多数浏览器依旧不支持,bable可以把ES6转码成ES5语法,这样我们就可以大胆的在项目中使用最新特性了

npm i babel-core babel-loader babel-preset-env babel-preset-stage-3 --save-dev复制代码

在项目根目录新建一个.babelrc文件

{  "presets": [    ["env", { "modules": false }],    "stage-3"  ]}复制代码

webpack.config.js添加一个loader

{    test: /\.js$/,    loader: 'babel-loader',    exclude: /node_modules/}复制代码

exclude表示忽略node_modules文件夹下的文件,不用转码

现在我们来试下async await语法吧 util.js

export default function getData() {    return new Promise((resolve, reject) => {        resolve('ok');    })}复制代码

main.js

import getData from './util';import Vue from 'vue';import './style/common.scss';var app = new Vue({  el: '#app',  data: {    message: 'Hello Vue!'  },  methods: {    async fetchData() {      const data = await getData();      this.message = data;    }  },  created() {    this.fetchData();  }});复制代码

这时控制台会报一个错误regeneratorRuntime is not defined,因为我们没有安装babel-polyfill

npm i babel-polyfill --save-dev复制代码

然后修改webpack.config.js的入口

entry: ['babel-polyfill', './src/main.js'],复制代码

重新npm run dev,可以发现正常运行了

引入图片资源

把图片也当成模块引入

npm i file-loader --save-dev复制代码

webpack.config.js添加一个loader

{    test: /\.(png|jpg|gif|svg)$/,    loader: 'file-loader',    options: {        name: '[name].[ext]?[hash]'    }}复制代码

在src目录下新建一个img目录,存放一张图片logo.png

修改main.js

import getData from './util';import Vue from 'vue';import './style/common.scss';Vue.component('my-component', {  template: '',  data() {    return {      url: require('./img/logo.png')    }  }})var app = new Vue({  el: '#app',  data: {    message: 'Hello Vue !'  },  methods: {    async fetchData() {      const data = await getData();      this.message = data;    }  },  created() {    this.fetchData()  }});复制代码

修改index.html

    
Document
{
{message}}
复制代码

可以看见,图片也被正确加载了

单文件组件

在前面的例子里,我们使用 Vue.component 来定义全局组件 在实际项目里,更推荐使用单文件组件

npm i vue-loader vue-template-compiler --save-dev复制代码

添加一个loader

{    test: /\.vue$/,    loader: 'vue-loader',    options: {        loaders: {            'scss': [                'vue-style-loader',                'css-loader',                'sass-loader'            ],            'sass': [                'vue-style-loader',                'css-loader',                'sass-loader?indentedSyntax'            ]        }    }}复制代码

在src目录下新建一个App.vue

复制代码

main.js

import Vue from 'vue';import App from './App.vue';import './style/common.scss';new Vue({  el: '#app',  template: '
', components: { App }})复制代码

index.html

    
Document
复制代码

npm run dev,可以发现单文件被正确加载了

source-map

在开发阶段,调试也是非常重要的一项需求。

App.vue

created() {    this.fetchData();    console.log('23333');}复制代码

我们故意打一个console,打开控制台

我们点击进入这个console的详细地址

进入的是打包后的build.js,我并不知道是在哪个组件里写的,这就造成了调试困难

这时就要修改webpack.config.js

module.exports = {    entry: ['babel-polyfill', './src/main.js'],    // 省略其他...    devtool: '#eval-source-map'};复制代码

重新npm run dev

这次调试,它直接返回那个组件的源代码了,这不是被打包过的!

打包发布

我们先试着npm run build打包一下文件

会发现,打包后的build.js非常大,有500多k了

在实际发布时,会对文件进行压缩,缓存,分离等等优化处理

npm i cross-env --save-dev复制代码

修改package.json

"scripts": {    "dev": "cross-env NODE_ENV=development webpack-dev-server --open --hot",    "build": "cross-env NODE_ENV=production webpack --progress --hide-modules"}复制代码

这次我们设置了环境变量,打包时,NODE_ENV是production

然后修改webpack.config.js,判断NODE_ENV为production时,压缩js代码

var path = require('path');var webpack = require('webpack');module.exports = {    // 省略...}if (process.env.NODE_ENV === 'production') {    module.exports.devtool = '#source-map';    module.exports.plugins = (module.exports.plugins || []).concat([      new webpack.DefinePlugin({        'process.env': {          NODE_ENV: '"production"'        }      }),      new webpack.optimize.UglifyJsPlugin(),    ])  }  复制代码

重新打包

可以看见,压缩效果非常明显!

至此,一个非常简单的vue开发环境搭建成功。

注意:本文中的配置还有非常多可以优化的地方,比如分离js和css

读者可以自行了解相关知识,这里只是带领大家了解最基础的webpack配置。

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

你可能感兴趣的文章
php多进程pcntl学习(采集新浪微博)
查看>>
[转]ListView学习笔记(一)——缓存机制
查看>>
【完全跨域】异步上传文件并获得返回值
查看>>
【TCP/IP详解 卷一:协议】第二章:链路层
查看>>
AWS开发人员认证考试样题解析
查看>>
Linux_DHCP服务搭建
查看>>
日请求亿级的 QQ 会员 AMS 平台 PHP7 升级实践
查看>>
【Coursera】Security Introduction -Eighth Week(2)
查看>>
Vue系列:如何将百度地图包装成Vue的组件
查看>>
Charles 从入门到精通
查看>>
MVC5 + EF6 简单示例
查看>>
Mysql Innodb存储引擎 insert 死锁分析
查看>>
好的用户界面-界面设计的一些技巧
查看>>
全端开发必备!10个最好的 Node.js MVC 框架
查看>>
初始Knockout
查看>>
HADOOP 2.6 INSTALLING ON UBUNTU 14.04 (hadoop 2.6 部署到ubuntu 14.04上面)
查看>>
OSSIM架构与组成综述
查看>>
用ASP.NET Core 2.0 建立规范的 REST API -- 预备知识 (2) + 准备项目
查看>>
数据分析:基于Python的自定义文件格式转换系统
查看>>
如何重置Sitecore CMS中的管理员密码
查看>>