webpack4-05-配置vue相关
栏目: JavaScript · 发布时间: 5年前
内容简介:webpack解析vue会用到的两个包分别为:安装:
webpack解析vue会用到的两个包分别为: vue-loader
、 vue-template-compiler
安装:
npm i vue-loader vue-template-compiler -D 复制代码
vue-loader
用于加载 .vue 后缀文件
vue-template-compiler
用于编译模板
还有我们的主角 vue
:
npm i vue -S 复制代码
注意:
在安装 vue-template-compiler
、 vue
包时,两个包的版本必须保持同步,这样 vue-loader
就会生成兼容运行时的代码。这意味着你每次升级项目中的 vue
包时,也应该匹配升级 vue-template-compiler
。
最新目录
lesson-05 |- build |- node-modules |- pubilc |- package.json |- package-lock.json |- /src |- assets |- images |- logon.png // 新增 |- App.vue // 新增 |- index.js |- main.js // 新增 复制代码
配置文件、App.vue、main.js
build/wbpack.config.js
const path = require('path') const HtmlWebpackPlugin = require('html-webpack-plugin') const CleanWebpackPlugin = require('clean-webpack-plugin') const autoprefixer = require('autoprefixer') const webpack = require('webpack') const { VueLoaderPlugin } = require('vue-loader') // 新增 const resolve = (dir) => path.resolve(__dirname, dir) module.exports = { mode: 'development', entry: { // app: ['@babel/polyfill', resolve('../src/index.js')] app: ['@babel/polyfill', resolve('../src/main.js')] // 修改入口文件 }, output: { filename: 'bundle.js', path: resolve('../dist') }, devServer: { open: true, hot: true, port: 3002, contentBase: resolve(__dirname, "./dist") }, module: { rules: [ { test: /\.jsx?$/, loader: 'babel-loader' }, { test: /\.(css|scss|sass)$/, use: [ // { // loader: 'vue-style-loader' // }, { loader: 'style-loader' }, { loader: 'css-loader', options: { importLoaders: 1 } }, { loader: 'sass-loader', options: { implementation: require('dart-sass') } }, { loader: 'postcss-loader' } ] }, { test: /\.(png|svg|jpg|gif)$/, loader: 'file-loader', options: { name: '[name].[ext]', }, }, { test: /\.vue$/, loader: 'vue-loader' }, { test: /\.vue$/, // 新增 loader: 'vue-loader' // 新增 } ] }, plugins: [ new VueLoaderPlugin(), // 新增 new CleanWebpackPlugin(), new HtmlWebpackPlugin({ title: 'Lesson-05', template: resolve('../public/index.html') }), new webpack.NamedModulesPlugin(), new webpack.HotModuleReplacementPlugin() ] } 复制代码
App.vue:
<style lang="scss" scoped> #app { display: flex; justify-content: center; align-items: center; flex-direction: column; font-size: 35px; } </style> <template> <div id="app"> <div><img src="./assets/images/logo.png"></div> <h1>Hello Vue</h1> </div> </template> <script> export default { name: 'App' } </script> 复制代码
main.js:
import Vue from 'vue' import App from './App.vue' new Vue({ el: '#box', render: h => h(App) }) 复制代码
现在可以尝试运行
npm run serve 复制代码
发现完美的跑起了一个简单的vue项目。
完美 +1
到这里其实还没有完,其实需要解决掉两个小问题。
main.js <img src="@/assets/images/logo.png">
其实这两个问题,都是用配置文件中 resolve
选项配置。
配置如下:
build/webpack.config.js
const path = require('path') const HtmlWebpackPlugin = require('html-webpack-plugin') const CleanWebpackPlugin = require('clean-webpack-plugin') const autoprefixer = require('autoprefixer') const webpack = require('webpack') const { VueLoaderPlugin } = require('vue-loader') const resolve = (dir) => path.resolve(__dirname, dir) module.exports = { mode: 'development', entry: { app: ['@babel/polyfill', resolve('../src/main.js')] }, output: { filename: 'bundle.js', path: resolve('../dist') }, devServer: { open: true, hot: true, port: 3002, contentBase: resolve(__dirname, "./dist") }, resolve: { // 新增 extensions:['.js', '.json', '.vue'], // 新增 alias:{ // 新增 '@': resolve('../src') // 新增 } // 新增 }, // 新增 module: { rules: [ { test: /\.jsx?$/, loader: 'babel-loader' }, { test: /\.(css|scss|sass)$/, use: [ // { // loader: 'vue-style-loader' // }, { loader: 'style-loader' }, { loader: 'css-loader', options: { importLoaders: 1 } }, { loader: 'sass-loader', options: { implementation: require('dart-sass') } }, { loader: 'postcss-loader' } ] }, { test: /\.(png|svg|jpg|gif)$/, loader: 'file-loader', options: { name: '[name].[ext]', }, }, { test: /\.vue$/, loader: 'vue-loader' } ] }, plugins: [ new VueLoaderPlugin(), new CleanWebpackPlugin(), new HtmlWebpackPlugin({ title: 'Lesson-05', template: resolve('../public/index.html') }), new webpack.NamedModulesPlugin(), new webpack.HotModuleReplacementPlugin() ] } 复制代码
注意:
resolve.extensions
选项默认值是['.js', '.json'],当配置的时候会把默认值给覆盖掉,所以需要把默认值的配置也加上,最终:
...省略 resolve: { extensions: ['.js', '.json', '.vue'] // ['.js', '.json']默认值 } ...省略 复制代码
App.vue
...省略 <template> <div id="app"> <div><img src="@/assets/images/logo.png"></div> // 新增@ <h1>Hello Vue</h1> </div> </template> ...省略 复制代码
main.js
import Vue from 'vue' import App from './App' // 省略了.vue后缀 new Vue({ el: '#box', render: h => h(App) }) 复制代码
再次运行
npm run serve 复制代码
能正常预览说明成功了!最终完成了vue配置。
更多相关的配置可以参vue-loader官方文档
以上所述就是小编给大家介绍的《webpack4-05-配置vue相关》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- vscode 配置eslint 开发vue的相关配置
- kubernetes高可用相关配置
- xampp 中 mysql的相关配置
- 手写Spring---配置config相关(5)
- Nginx介绍及Web服务相关配置
- DuckChat 1.1.2 发布,增加众多安全相关配置
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Rails 5敏捷开发
[美] Sam Ruby、[美] Dave Thomas、[美] David Heinemeier Hansson / 安道、叶炜、大疆Ruby技术团队 / 华中科技大学出版社 / 2017-12-30 / 115.00
本书以讲解“购书网站”案例为主线,逐步介绍Rails的内置功能。全书分为3部分,第一部分介绍Rails的安装、应用程序验证、Rails框架的体系结构,以及Ruby语言知识;第二部分用迭代方式构建应用程序,然后依据敏捷开发模式开展测试,最后用Capistrano完成部署;第三部分补充日常实用的开发知识。本书既有直观的示例,又有深入的分析,同时涵盖了Web开发各方面的知识,堪称一部内容全面而又深入浅出......一起来看看 《Rails 5敏捷开发》 这本书的介绍吧!