目前最的正式版本是:4.31.0,推薦使用本地安裝, webpack官網-指南
node -v
mkdir demo
npm init -y
const path = require('path'); module.exports = { entry:'./src/index.js'. ouyput:{ path: path.resolve(__dirname,'dist'), filename: 'bundle.js', } }
npm i webpack-dev-server -D
"dev": "webpack-dev-server --open --port 3000 --contentBase src --hot"
代碼npm run dev
,便可打包文件npm install --save-dev html-webpack-plugin
const HtmlWebpackPlugin = require('html-webpack-plugin');
plugins:[new HtmlWebpackPlugin({template:'./dist/index.html'})]
npm install --save-dev style-loader css-loader
module:{reules:[{test:/\.css$/,use:['style-loader','css-loader']}]}
npm install -D babel-loader @babel/core @babel/preset-env webpack
module: { rules: [ { test: /\.js$/, exclude: /node_modules/, use: { loader: 'babel-loader', options: { presets: ['@babel/preset-env'] } } } ] }
npm install -D @babel/plugin-transform-runtime
use: { loader: 'babel-loader', options: { presets: ['@babel/preset-env'], plugins: ['@babel/plugin-transform-runtime'] } }
npm i vue -D
# const VueLoaderPlugin = require('vue-loader/lib/plugin'); # resolve:{ alias:{ 'vue$':"vue/dist/vue.esm.js" } }
npm install -D vue-loader vue-template-compiler
+ const VueLoaderPlugin = require('vue-loader/lib/plugin'); - rules: [ // ... 其它規則 { test: /\.vue$/, loader: 'vue-loader' } ] - plugins: [ // 引入這個插件! new VueLoaderPlugin() ]
附上源代碼css
webpack.config.jshtml
const path = require('path'); const VueLoaderPlugin = require('vue-loader/lib/plugin'); const HtmlWebpackPlugin = require('html-webpack-plugin'); module.exports = { entry: './src/index.js', output: { path: path.resolve(__dirname,'dist'), filename: 'bundle.js', }, plugins:[ new VueLoaderPlugin(), new HtmlWebpackPlugin({ template:'./src/index.html' }), ], module:{ rules:[ { test: /\.css$/, use: [ 'style-loader', 'css-loader' ] }, { test:/\.(png|svg|ipg|gif)$/, use:['file-loader'] }, { test:/\.vue$/, loader:'vue-loader' }, { test: /\.js$/, exclude: /node_modules/, use: { loader: 'babel-loader', options: { presets: ['@babel/preset-env'], plugins: ['@babel/plugin-transform-runtime'] } } }, ] }, resolve:{ alias:{ 'vue$':"vue/dist/vue.esm.js" } } }
package.jsonvue
{ "name": "mint-demo", "version": "1.0.0", "description": "\"", "main": "index.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1", "dev": "webpack-dev-server --open --port 3000 --contentBase src --hot" }, "author": "", "license": "ISC", "devDependencies": { "@babel/core": "^7.4.4", "@babel/plugin-transform-runtime": "^7.4.4", "@babel/preset-env": "^7.4.4", "babel-loader": "^8.0.6", "css-loader": "^2.1.1", "file-loader": "^3.0.1", "html-webpack-plugin": "^3.2.0", "style-loader": "^0.23.1", "vue-loader": "^15.7.0", "vue-template-compiler": "^2.6.10", "webpack": "^4.31.0", "webpack-cli": "^3.3.2", "webpack-dev-server": "^3.3.1" }, "dependencies": { "vue": "^2.6.10" } }
index.jsnode
import Vue from 'vue'; import App from './App.vue'; console.log('444'); var app = new Vue({ el:'#app', data:{ msg:'ccc' }, render: c => c(App) }) console.log('2323');
index.htmlwebpack
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>vue</title> </head> <body> <div id="app"> {{msg}} </div> </body> </html>
App.vueweb
<template> <div> 這是app.vue </div> </template> <script> export default { } </script> <style scoped> </style>
歡迎指正哦!
參照:
webpack官網
vue官網npm