首頁  >  文章  >  web前端  >  在Vue+webpack中詳細講解基礎配置

在Vue+webpack中詳細講解基礎配置

亚连
亚连原創
2018-06-06 09:55:072881瀏覽

這篇文章主要介紹了Vue webpack專案基礎設定教學,需要的朋友可以參考下

最近在學習webpack,跟著課程一個單頁應用,在這裡記錄一下。這個部分主要講如何設定webpack的環境,以及webpack dev的設定。

記錄比較粗略,後續會更新。

1.開發環境:vscode,node.js,vue.js,webpack

大家自己安裝node.js可以參考菜鳥教學

#使用的IDE是VScode

2.專案初始化

快捷鍵ctrl ` 開啟vscode控制台

#vscode介面

2.1安裝webpack vue vue-loader

npm init
npm i webpack vue vue-loader

npm 出現warn提醒你需要依賴,並依照提示進行安裝

## 

warn

安裝對應的loader

npm i css-loader vue-template-compiler

2.2設定webpack可以載入app.vue檔案

#先建立src資料夾,並在其下方建立app.vue最為主程式碼文件,index.js作為入口文件。

 

基礎檔案

app.vue檔案內容如下:

<template>
 <p id="text">{{text}}</p>
</template>
<script>
 export default{
 data(){
  return {
  text: &#39;abc&#39;
  }
 }
 }
</script>
<style>
 #test{
 color: red;
 }
</style>

在src同級目錄下

創建webpack.config.js文件,設定入口entry,輸出output

 

建立package.json檔案和webpack.config.js檔案

//webpack.config.js
const path = require(&#39;path&#39;)
module.exports = {
 entry: path.join(__dirname,&#39;src/index.js&#39;), //调用Index.js作为入口文件
 output: { //打包完的js文件会在bundle.js中,这个文件待会会自动生成的
 filename: &#39;bundle.js&#39;, 
 path: path.join(__dirname,&#39;dist&#39;) //用来存放bundle.js文件的地址,自己定义
 },
 module: {
 rules: [{
  test: /.vue$/,
  loader: &#39;vue-loader&#39;
 }]
 }
}

#index.js檔案作為入口

//index.js
import Vue from &#39;vue&#39;
import App from &#39;./app.vue&#39;
const root = document.createElement(&#39;p&#39;)
document.body.appendChild(root)
new Vue({
 render: (h) => h(App)
}).$mount(root)

配置package.json檔案中的scripts指令,加入build

"scripts": {
 "test": "echo \"Error: no test specified\" && exit 1",
 "build": "webpack --config webpack.config.js"
 },

在控制台輸入npm run build 指令進行打包,打包成功後如圖

 

webpack打包完成後

2.3設定webpack可以載入非Js檔案

webpack.config.js檔案特定設定

在webpack .config.js中的module: {}模組中加入rules:[],可以設定webpack需要識別的檔案類型,之前已經設定了vue檔案類型,好需要加入css/圖片。

//webpack.config.js 
module: {
 rules: [
 {
 test: /.vue$/,
 loader: &#39;vue-loader&#39;
 },
 {
 test: /.css$/,
 use:[
 &#39;style-loader&#39;,
 &#39;css-loader&#39;
 ]
 },
 {
 test: /\.(gif|jpg|png|svg)$/,
 use: [{
  loader: &#39;url-loader&#39;,
  options: {
  limit: 1024,
  name:&#39;[name].[ext]&#39;
  }
 }]
 }
] 
}

在控制台執行指令,安裝對應的loader

npm i style-loader css-loader url-loader file-loader

測試非js類型檔案包裝效果

目標:在js程式碼中import這些非js類型的文件中的內容

再src子目錄下,建立測試檔test.css。以及在images中放入jpg圖片代用(一張就可以了,emmm我當時放多了就先不刪了)

 

src下檔結構

在Index.js中import這些非js檔案。

//index.js
import Vue from &#39;vue&#39;
import App from &#39;./app.vue&#39;
import &#39;./assets/styles/test.css&#39; //import css文件
import &#39;./assets/images/0.jpg&#39; //import 图片
const root = document.createElement(&#39;p&#39;)
document.body.appendChild(root)
new Vue({
 render: (h) => h(App)
}).$mount(root)

最後在控制台執行

npm run build 測試結果。

打包成功圖片類似上面。

2.4關於css預處理器。 stylus的設定和測試

stylus是css的一種預處理器,檔案類型是.styl 我們在這裡對其進行設定

首先在webpack.config.js檔案中的rules: []模組中跟上面一樣,加入如下程式碼,讓其可以辨識.styl檔

//webpack.config.js
  {
  test:/.styl$/,
  use: [
   &#39;style-loader&#39;,
   &#39;css-loader&#39;,
   &#39;stylus-loader&#39;
  ]
  }

然後在控制台安裝stylus所需的loader檔

npm i style-loader stylus-loader

最後在控制台執行

npm run build 測試結果。

2.5配置webpack-dev-server:專門用在開發環境的打包

因為正式環境和我們的開發環境有所區別,所以需要配置dev用來區分

首先,安裝webpack-dev-server

npm i webpack-dev-server

然後, 修改package.json文件,在build下面添加dev配置

 

package.json文件設定

然後,修改webpack.config.js

在全域加入target:'web'

 

config.js

因為這個檔案要同時用在開發環境和正式環境,所以要加一個環境判斷,在跑npm的時候加入變數標識不同環境。

因為windows和mac環境下的指令會不同,這裡安裝cross-env 套件,使得在不同開發環境下指令相同。

npm i cross-env

再次修改package.json檔,在「build:」和「dev:"行加入dev指令

cross-env NODE_ENV=development  後面不變

package.json檔案build

##

然后,在webpack.config.js文件中进行判断。

首先,配置config.devServer

webpack2之后就可以直接用config.devServer进行配置了。

更改文件头部几行代码

 

在文件的最后加上如下代码

 

config.devServer

注意:
host:'0.0.0.0'不要直接写localhost,这样别人的电脑就访问不了了;port不要被占用,不然会打不开

最后.安装html-webpack-plugin插件使得html可以作为入口,自动包含JS

npm i html-webpack-plugin

修改webpack.config.js文件

 

config.js

 

config.js

至此,dev配置基本完成

控制台执行 npm run dev

npm run dev

打包成功的话就可以在浏览器中查看效果了,

如果出现错误,根据提示修改,注意端口是否占用。我的8000端口占用了,后来用了8080端口就好了

浏览器访问:localhost:8080,可以查看渲染效果。恩,背景图0.jpg是我爱豆23333。笔芯。注意左上角有红色的abc。

 

浏览器效果

2.6最后还有一些东西要加在config.js中

最后还要加一些东西

1) historyFallback:{}

因为我们做的是单页应用,所以要加一下地址映射到入口index.html,这个先忽略

2) 热加载功能。

hot功能,可以实现局部渲染:比如你改了一个组件的代码,页面只重新渲染这个组件而不是整个页面进行渲染,不需要进行刷新操作。

3) 一些插件

webpack.HotModuleReplacementPlugin()启动hot功能

webpack.NoEmitOnErrorsPlugin()去除一些不必要的信息

4) 浏览器调试代码功能的工具

在浏览器中调试的时候,代码不会转码。

config.devtool = “#cheap-module-evel-source-map”

 

最后配置完成后,重新npm run dev一次

npm run dev

成功之后,可以在浏览器中测试热加载效果,修改app.vue文件中的text的内容,就可以看到左上角那个红色的字在变了emmmm

//app.vue
<template>
 <p id="text">{{text}}</p>
</template>
<script>
 export default{
 data(){
  return {
  text: &#39;abc&#39; //打开浏览器,然后直接改这里就可以实时看到文字变化效果了。
  }
 }
 }
</script>
<style>
 #test{
 color: red;
 }
</style>

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在vue中如何实现webpack打包优化

使用vue和react来实现展开收起等效果

在Vue 2.5.2下使用axios + express本地请求404的解决方法

以上是在Vue+webpack中詳細講解基礎配置的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn