VUE 完整項目構建 (1) -- 初始化

前置條件:

  1. 熟悉使用 Javascript + HTML5 + css3。
  2. 理解 ES2015 Module 模塊(export、import、export-default)。
  3. 瞭解 nodejs 基礎知識,npm 經常使用命令,以及 npm script 使用 (vue 項目中使用 npm 進行包管理)。
  4. 瞭解 webpack 打包工具 (經常使用配置選項以及 loader 概念)。(webpack webpack.github.io/ 是一個模塊打包工具。它將一堆文件中的每一個文件都做爲一個模塊,找出它們的依賴關係,將它們打包爲可部署的靜態資源。webpack 的使用也須要 npm 的安裝方式)。

開始安裝:

使用 vue-cli 構建大型單頁應用:vue.js 的腳手架工具。css

執行下述代碼,便可完成項目基礎構建(已配置好 webpack、依賴包的安裝、基本目錄的生成)。html

# 全局安裝 vue-cli

$ npm install --global vue-cli

# 建立一個基於 webpack 模板的新項目

$ vue init webpack my-project

# 安裝依賴,走你

$ cd my-project

$ npm install

$ npm run dev
複製代碼

主要目錄:

├── build // webpack的基本配置、開發環境配置、生產環境配置
    ├── config // 路徑、端口以及反向代理配置
    ├── dist // webpack打包後的靜態資源
    ├── node_modules // npm安裝的依賴包
    ├── src // 前端主文件
    │   ├── assets // 靜態資源
    │   │   ├── font
    │   │   ├── img
    │   │   └── scss
    │   ├── components // 單個組件
    │   │   ├── xxx.vue // 單文件組件
    │   ├── router // 路由配置
    │   ├── store // 全局變量
    │   ├── App.vue // App組件
    │   ├── main.js 主入口文件
    ├── static // 靜態文件
    ├── .babelrc  // babel的配置項
    ├── .editorconfig  // 編輯器的配置項
    ├── .gitignore  // 會忽略語法檢查的目錄
    ├── index.html // 入口頁面
    ├── package.json // 項目的描述和依賴 
複製代碼

package.json文件說明:項目的描述和依賴前端

1. scripts:編譯項目的一些命令vue

例:執行 npm run dev,即執行 scripts 中對應的 node build/dev-server.js。node

2. dependencies:項目發佈時的依賴webpack

例:執行 npm install wx --save,即安裝依賴模塊 wx。ios

3. devDependencies:項目開發時的依賴css3

例:執行 npm install sass --save-dev,即安裝依賴模塊 sass。git

附:npm 相關說明:github

npm 爲 Node.js 版本管理和依賴包管理工具,經過 node 環境來安裝前端構建項目所需依賴包。

npm 安裝下載速度過慢,使用淘寶鏡像 cnpm install 快速安裝。設置方法:

$ npm install -g cnpm --registry=https://registry.npm.taobao.org

項目加載過程:

1. index.html 頁面

當前構建項目爲 SPA (單頁面應用),index.html 頁面即爲入口頁面,進行meta 等相關頁面配置。

​該頁面的 <div id="app"></div> 掛載了主組件。

2. main.js:主入口文件

​注: 在 webpack.base.config 中設置 -> entry: { app: './src/main.js'}

​該文件初始化 vue 實例並引入相應模塊 (引入前需確認在 package.json 中進行配置並安裝),附 main.js 引入及說明:

import Vue from 'vue'   // 引入vue
​	
​	import App from './App'   // 引入主組件App.vue
​	
​	import router from './router' // 引入路由配置文件
​	
​	import axios from 'axios' // 引入網絡請求工具axios
複製代碼

3. App.vue:主組件

​在 index.html 入口頁面中掛載了主組件,並在 main.js 主入口文件中引入了主組件。

​建立了其餘組件 (例:/src/components/xxx.vue)後,經過路由配置便可渲染在當前主組件中。

4. 路由配置 vue-router

​路由配置:將組件 (components) 映射到路由 (routes),而後告訴 vue-router 在哪裏渲染它們

npm install vue-router
複製代碼
import Vue from 'vue'

import Router from 'vue-router'

Vue.use(Router)

// 1.定義(路由)組件:import (當前應用中爲單文件組件)。
import Home from '../components/Home.vue'

// 2. 定義路由並建立 router 實例,而後傳 `routes` 配置
// 每一個路由應該映射一個組件。
var router = {}

export default router = new Router({
  routes: [
    {
      path: '/',
      name: 'home',
      component: Home
    }
   ]
})

// 3. 在main.js主入口文件中建立和掛載根實例。
// 記得要經過 router 配置參數注入路由,
// 從而讓整個應用都有路由功能

new Vue({
  el: '#app',
  router,
  template: '<App/>',
  components: { App }
})

// 如今,應用已經啓動了!
複製代碼

Next

下節一塊兒討論網絡請求與組件的建立。

「未完待續」


coding01 期待您繼續關注

qrcode


也很感謝您能看到這了

qrcode
相關文章
相關標籤/搜索