自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

跟我學(xué) “Linux” 小程序 Web 版開發(fā)(一):初始化

開發(fā) 前端 Linux
從今天起,我們將在 Linux 中國(guó)官網(wǎng)和公眾號(hào)上,連載 TL;DR Web 應(yīng)用開發(fā)背后的故事。接下來(lái),請(qǐng)看來(lái)自開發(fā) gg 的文章。

 

“Linux” 小程序是 Linux 中國(guó)在 2019 年 2 月(恰恰是去年春節(jié))發(fā)布的小程序,該小程序采用眾包模式,對(duì)著名的 TLDR 項(xiàng)目中的 Linux 命令示例進(jìn)行了翻譯,并通過(guò)微信小程序的形式展現(xiàn)。在 2020 年的春節(jié),我們面向更多的 PC 端用戶,開放了 Web 版的 Linux 命令查詢。Web 版和小程序版數(shù)據(jù)同步,讓你在使用桌面計(jì)算機(jī)時(shí)也可以進(jìn)行命令查詢。

從今天起,我們將在 Linux 中國(guó)官網(wǎng)和公眾號(hào)上,連載 TL;DR Web 應(yīng)用開發(fā)背后的故事。接下來(lái),請(qǐng)看來(lái)自開發(fā) gg 的文章。

背景描述

Linux 中國(guó)曾在過(guò)去的一年開發(fā)和運(yùn)行了一個(gè)中國(guó)版 TL;DR 客戶端。不過(guò)當(dāng)時(shí)做的版本是小程序的版本,一直以來(lái),受限于小程序·云開發(fā)沒有 Web SDK ,因此無(wú)法將應(yīng)用能力遷移到更多的平臺(tái)上。剛好最近云開發(fā)提供了 Web SDK,并已經(jīng)逐步成熟,于是我們便可以借此機(jī)會(huì),將業(yè)務(wù)實(shí)現(xiàn) PC 化,服務(wù)更多人群。

在開發(fā)出初步的版本之后,我們決定以這個(gè)項(xiàng)目作為范例,將我們開發(fā)經(jīng)驗(yàn)分享給大家,大家可以參考開發(fā)自己的云應(yīng)用。

項(xiàng)目設(shè)計(jì)

在進(jìn)行項(xiàng)目開發(fā)時(shí),先對(duì)項(xiàng)目進(jìn)行了基本的 UI 設(shè)計(jì):

主頁(yè)

詳情頁(yè)

這里用到的是 balsamiq 的手繪線框圖來(lái)完成產(chǎn)品設(shè)計(jì),以避免我個(gè)人過(guò)度追求完美,而讓產(chǎn)品延期遲遲不能上線的問(wèn)題(這樣的事情在歷史上發(fā)生了非常多次)

技術(shù)選項(xiàng)

由于需要的是一個(gè)前端頁(yè)面,因此,在技術(shù)選型方面,幾乎沒有太多的異議。使用最為熟悉的技術(shù)棧來(lái)完成。

  • 前端框架:Vue
  • 路由器:Vue Router
  • CSS 框架:Vuetify.js

鏡像配置

因?yàn)樯硖巼?guó)內(nèi), npm 的速度必然不太好,因此需要進(jìn)行相應(yīng)的鏡像設(shè)定,確保 npm 和 yarn 在安裝依賴。這里使用的是騰訊云提供的鏡像。

  1. # Npm 設(shè)置
  2. npm config set registry http://mirrors.cloud.tencent.com/npm/
  3.  
  4. # yarn 設(shè)置
  5. yarn config set registry http://mirrors.cloud.tencent.com/npm/ -g

初始化 Vue 項(xiàng)目

首先,需要安裝 Vue CLI,以進(jìn)行項(xiàng)目的生成,這里我已經(jīng)完成安裝,就不再贅述。(Vue CLI 的安裝教程點(diǎn)擊這里

執(zhí)行如下命令初始化項(xiàng)目:

  1. vue create tldr

等待其完成安裝以后,進(jìn)入項(xiàng)目,并啟動(dòng)項(xiàng)目。

  1. cd tldr
  2. yarn serve

隨即,可以在瀏覽器中訪問(wèn) localhost:8080 查看項(xiàng)目:

預(yù)覽

記得引入 git 做版本控制,文章里就不介紹了。沒意思。

安裝 Vue Router

在完成 Vue 項(xiàng)目的初始化以后,接下來(lái)需要進(jìn)行 Vue Router 的配置了。

Vue Router 的配置在引入了 Vue 3 以后,顯得非常的簡(jiǎn)單,直接執(zhí)行如下命令即可:

  1. vue add router

執(zhí)行過(guò)程中,會(huì)問(wèn)你是否需要啟用 History Mode,根據(jù)需要選取,我使用的是 History Mode。

設(shè)置完成以后,保存并重啟 Vue 的開發(fā)服務(wù)器,你會(huì)在預(yù)覽中看到 Router 添加的 “Home” 和 “About”。

安裝 Vuetify.js

接下來(lái)安裝的是 Vuetify.js ,由于框架提供了相應(yīng)的支持,因此在開發(fā)時(shí)也非常簡(jiǎn)單,只需要執(zhí)行如下命令就可以完成初始化。

  1. vue add vuetify

會(huì)問(wèn)你選擇那種預(yù)設(shè),直接使用 Default 即可。

保存并重啟開發(fā)服務(wù)器,你會(huì)看到這樣的界面,則說(shuō)明配置完成。

部署測(cè)試應(yīng)用

在進(jìn)行下一步開發(fā)的時(shí)候,需要先進(jìn)行一下項(xiàng)目的部署,從而獲得一個(gè)測(cè)試的域名,方便后續(xù)的開發(fā)。

這里項(xiàng)目的開發(fā)我并沒有使用云開發(fā)自己的 Web 托管 (因?yàn)槲覀儾皇前戳扛顿M(fèi)套餐,所以沒有辦法開啟),而是使用了 Now.sh 的,這里就不再過(guò)多贅述。

引入云開發(fā) SDK

云開發(fā)提供了 Web SDK ,可以通過(guò) npm 安裝,并引用。

執(zhí)行如下命令來(lái)安裝:

  1. yarn add tcb-js-sdk

安裝完成后,在 main.js 中引入 tcb,并通過(guò)修改 Vue 的原型來(lái)實(shí)現(xiàn)掛載 Vue。

  1. import Vue from 'vue'
  2. import App from './App.vue'
  3. import router from './router'
  4. import vuetify from './plugins/vuetify';
  5. const tcb = require('tcb-js-sdk') // 新增的引入 TCB
  6.  
  7. Vue.config.productionTip = false
  8.  
  9. Vue.prototype['$tcb'] = tcb.init({ // 新增的修改原型
  10. env: 'prod-2c59c7' // 新增的修改原型
  11. }) // 新增的修改原型
  12.  
  13. new Vue({
  14. router,
  15. vuetify,
  16. render: h => h(App)
  17. }).$mount('#app')

這樣就可以在應(yīng)用運(yùn)行的整個(gè)周期中使用 this.$tcb 來(lái)調(diào)用云開發(fā)的相關(guān)邏輯。

總結(jié)

在完成了項(xiàng)目的初始化以后,回過(guò)頭來(lái)看一看這在初始化項(xiàng)目過(guò)程中,都做了哪些事情。

  1. 配置 npm 鏡像,以確保 Node 包的安裝速度
  2. 使用 Vue CLI 來(lái)初始化項(xiàng)目
  3. 安裝 Vue Router & Vuetify.js
  4. 部署應(yīng)用
  5. 安裝 tcb-js-sdk 以調(diào)用云開發(fā)數(shù)據(jù)

請(qǐng)期待本系列的下一篇關(guān)于界面開發(fā)的文章。

 

責(zé)任編輯:龐桂玉 來(lái)源: Linux中國(guó)
相關(guān)推薦

2020-02-04 10:05:54

LinuxWeb命令

2020-02-05 09:20:37

LinuxWeb前端

2020-02-06 16:23:00

LinuxWeb前端

2022-02-16 09:42:33

Linuxapt命令軟件包

2021-03-22 09:10:28

NginxNginx 簡(jiǎn)介服務(wù)器

2010-05-18 10:46:46

2011-12-05 10:37:53

Linux服務(wù)器Shell腳本

2023-03-31 11:14:13

java虛擬機(jī)指令

2023-08-10 08:01:21

2011-03-31 16:46:10

LinuxMySQL

2023-11-12 23:08:17

C++初始化

2011-08-24 14:26:08

Lua游戲腳本

2010-02-24 15:41:19

Linux Light

2020-11-26 11:25:44

VimLinuxPython IDE

2017-04-26 14:48:01

Chrome程序擴(kuò)展

2009-08-28 11:24:48

C#一維數(shù)組初始化

2011-06-17 15:29:44

C#對(duì)象初始化器集合初始化器

2011-07-06 14:16:25

Linux服務(wù)器Shell腳本

2010-06-21 10:25:09

Linux APM

2021-03-12 10:30:11

SpringMVC流程初始化
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)