vue-cli構(gòu)建vue項目的步驟詳解
構(gòu)建一個 vue 項目最簡單的方式就是使用腳手架工具 vue-cli 。前端的三大框架都有自己的腳手架工具,其作用就是用配置好的模板迅速搭建起一個項目工程來,省去自己配置 webpack 配置文件的基本內(nèi)容,大大降低了初學(xué)者構(gòu)建項目的難度。這節(jié)我們看看如何使用 vue-cli 構(gòu)建 vue 項目以及對構(gòu)建項目的具體分析。
一、環(huán)境搭建
node 和 npm 是必不可少的,這里不再介紹。
1、安裝 vue-cli
$ npm install -g vue-cli
檢查是否安裝成功:
$ vue --version 3.3.0
<!-- more -->
2、構(gòu)建項目
$ vue init webpack hello-vue
初始化的過程中,會有一個交互式的選項讓你選擇項目的一些配置,根據(jù)項目需求選擇即可。為了方便后面幾篇教程的演示,可以統(tǒng)一選擇以下選項:
? Project name hello-vue # 項目名稱 ? Project description A Vue.js project # 項目描述 ? Author Deepspace <cxin1427@gmail.com> # 作者 ? Vue build standalone # 運行+編譯時 ? Install vue-router? Yes # 安裝 vue-router ? Use ESLint to lint your code? Yes # 使用 ESLint 作為代碼規(guī)范 ? Pick an ESLint preset Airbnb # 選擇 Airbnb 的代碼規(guī)范 ? Set up unit tests Yes # 安裝單元測試 ? Pick a test runner karma # 測試模塊 ? Setup e2e tests with Nightwatch? Yes # 安裝 e2e 測試 ? Should we run `npm install` for you after the project has been created? (recommended) npm # 包管理器,npm
構(gòu)建完成之后,會提示構(gòu)建成功信息:
# Project initialization finished! # ======================== To get started: cd hello-vue npm run dev Documentation can be found at https://vuejs-templates.github.io/webpack
3、啟動項目
$ cd hello-vue $ npm run dev
項目默認會在 8080 端口啟動,如果端口有占用,會自動調(diào)整端口。打開瀏覽器輸入:http://localhost:8080,會看到構(gòu)建的項目的主頁:

4、目錄結(jié)構(gòu)
使用編輯器打開(推薦使用 VSCode),下面具體看看目錄結(jié)構(gòu):
package.json :
{
"scripts": {
"dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
"start": "npm run dev",
"unit": "cross-env BABEL_ENV=test karma start test/unit/karma.conf.js --single-run",
"e2e": "node test/e2e/runner.js",
"test": "npm run unit && npm run e2e",
"lint": "eslint --ext .js,.vue src test/unit test/e2e/specs",
"build": "node build/build.js"
}
}
在 package.json 中,根據(jù)我們在構(gòu)建項目的時候的選項,有以下幾個命令。
npm run dev:項目開發(fā)階段,項目啟動的命令;npm run lint:使用eslint檢查代碼格式;npm run test:單元測試和e2e測試;npm run e2e:e2e測試;npm run build:開發(fā)完成后執(zhí)行,會把我們的源代碼編譯成最終的發(fā)布代碼,生成在項目根目錄中的dist文件夾下(初始化項目時不會生成)。
config: 保存一些項目初始化配置。
build :里面保存一些 webpack 的初始化配置。
index.html : 是我們的首頁。index 很多時候都被預(yù)設(shè)為首頁,像 index.htm,index.php 等。
src : 保存項目源代碼的地方,我們下面會詳細分析該文件夾里的文件。
二、代碼分析
Vue 的核心架構(gòu)分為兩個部分:路由和組件,其實 React 也是一樣的。我們在切入一個項目的時候,都是從這兩個點出發(fā)。下面我們具體看看 src 文件夾。
1、入口文件
如果我們打開項目根目錄下 build 目錄中的 webpack.base.conf.js,會看到這樣的代碼(第22行):
module.exports = {
context: path.resolve(__dirname, '../'),
entry: {
app: './src/main.js'
},
// ...
}
說明我們的入口文件就是 src 目錄下的 main.js 文件??纯创a:
// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue';
import App from './App';
import router from './router';
Vue.config.productionTip = false;
/* eslint-disable no-new */
new Vue({
el: '#app',
router,
components: { App },
template: '<App/>',
});
看看這里面做了什么事情:
- 引入
vue并起名叫作Vue - 引入根目錄下的
App.vue文件(后綴名可不要) - 引入
router文件下的index.js文件(文件夾后沒有具體的文件,默認引入的就是index.js文件) - 通過
new實例化Vue實例 ,實例化的時候聲明了幾個屬性:el:'#app':意思是將所有視圖放在id值為app這個dom元素中,也就是項目根目錄下的index.html中的那個div:<div id="app"></div>;components: { App }:意思是將上面引入的App.vue文件的內(nèi)容將以<App/>這樣的標簽寫進<div id="app"></div>中;
在開始的時候,我們并沒有介紹說 Vue 使用的是虛擬 DOM ,那么,從這里我們看出,Vue 使用的也是虛擬 DOM (和React是一樣的)。
這里對虛擬DOM作下簡單介紹:當我們修改應(yīng)用程序時,不會對DOM進行更改,而是創(chuàng)建以JavaScript數(shù)據(jù)結(jié)構(gòu)形式存在的DOM副本,然后插到文檔當中。無論何時進行任何更改,都將對JavaScript數(shù)據(jù)結(jié)構(gòu)進行更改,并將后者與原始數(shù)據(jù)結(jié)構(gòu)進行比較(diff算法),然后將最終更改更新為真實DOM。我們都知道DOM是非常重的,所以虛擬DOM是非常省性能的。
2、App.vue
通過入口文件中做的事情,我們其實已經(jīng)知道 App.vue 的作用了:單頁面應(yīng)用的主組件。所有頁面都是在 App.vue 下通過路由進行切換的。所以,我們可以理解為所有的路由(route)也是 App.vue 的子組件。我們看看代碼:
<template>
<div id="app">
<img src="./assets/logo.png">
<router-view/>
</div>
</template>
<script>
export default {
name: 'App',
};
</script>
<style>
#app {
font-family: 'Avenir', Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
</style>
這里需要提一下:node之所以可以識別出*·vue格式的文件,是因為webpack在編譯時將*.vue文件中的html、js、css都抽出來形成新的單獨文件??赏ㄟ^npm run build命令編譯源代碼,查看dist文件下的文件來驗證。
App.vue 的內(nèi)容分為三個部分:<template>...</template>、<script>...</script>、<style>...</style> ,分別在這三類標簽里面寫入結(jié)構(gòu)、腳本、樣式。
我們先從 <template> 看起:里面一個 div 包裹著 img 標簽和 router-view 標簽。前面提到過: App.vue 是單頁面應(yīng)用的主組件。對照著前面在瀏覽器中打開的應(yīng)用主頁面,img 標簽就是頁面上方的 Vue 的 logo。那下面的內(nèi)容去哪了呢?和 <router-view/> 有關(guān)系嗎?這就要去看路由了。
3、router/index.js
import Vue from 'vue';
import Router from 'vue-router';
import HelloWorld from '@/components/HelloWorld';
Vue.use(Router);
export default new Router({
routes: [
{
path: '/',
name: 'HelloWorld',
component: HelloWorld,
},
],
});
前面先引入了路由插件 vue-router,然后顯式聲明要用路由 Vue.use(Router) 。路由的配置非常地明了:給不同 path 分配不同的組件(或者頁面),參數(shù) name 只是用來識別。
當我訪問根路由 http://localhost:8080/#/ 時,App.vue 中的 <router-view/> 就會把引入的 HelloWorld 組件分配給我,放在了 img 標簽的下面,打開 components 目錄下的 HelloWorld.vue 就可以看到具體內(nèi)容了。
我們在看到瀏覽器中的url的時候會覺得奇怪,為什么在后面加了一個#號呢?這是因為vue-router默認hash模式 —— 使用URL的hash來模擬一個完整的URL,當 URL 改變時,頁面不會重新加載。詳見:https://router.vuejs.org/zh/guide/essentials/history-mode.html。這里可先跳過這點內(nèi)容。
現(xiàn)在,我們在瀏覽器訪問 http://localhost:8080/#/vue 這個地址,會發(fā)現(xiàn)只出現(xiàn)了 Vue 的 logo。這是因為我們并沒有配置 /vue 這個路由,找不到路由,那<router-view/> 這個標簽就不會加載出來。
到這里,我們就知道路由是如何根據(jù) url 來分配不同的組件了。配置多個路由就很簡單了:
export default new Router({
routes: [
{
path: '/',
name: 'HelloWorld',
component: HelloWorld
},
{
path: '/about',
name: 'about',
component: About
},
{
path: '/vue',
name: 'vue',
component: Vue
}
]
})
那如果要訪問 http://localhost:8080/#/vue/demo 怎么辦呢?
export default new Router({
routes: [
{
path: '/',
name: 'HelloWorld',
component: HelloWorld,
},
{
path: '/about',
name: 'about',
component: About,
},
{
path: '/vue',
name: 'vue',
component: Vue,
children: [
{
path: '/demo',
component: demo,
},
{
path: '/project',
component: project,
},
],
},
],
});
給路由加多一個子路由配置即可。
4、assets
用來存放一些圖片、樣式等靜態(tài)文件。
三、總結(jié)

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue項目中如何使用TypeScript相關(guān)配置
這篇文章主要給大家介紹了關(guān)于vue項目中如何使用TypeScript相關(guān)配置的相關(guān)資料,typescript在開發(fā)過程中廣泛被應(yīng)用,在這里總結(jié)下項目中ts的應(yīng)用,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2023-11-11
vue使用el-upload實現(xiàn)文件上傳的實例代碼
這篇文章主要為大家詳細介紹了vue使用el-upload實現(xiàn)文件上傳,文中示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或工作有一定的幫助,感興趣的小伙伴們可以參考一下2024-01-01
解析vue?3.0?使用axios庫發(fā)起?post?get?的配置過程
get post 請求開發(fā)中最普通最常見的請求方式但是在vue中如何實現(xiàn)呢 這里記錄一下配置過程,對vue?使用axios發(fā)起?post?get配置過程感興趣的朋友一起看看吧2022-05-05
淺談vue websocket nodeJS 進行實時通信踩到的坑
這篇文章主要介紹了淺談vue websocket nodeJS 進行實時通信踩到的坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09

