知識
不管是網(wǎng)站,軟件還是小程序,都要直接或間接能為您產(chǎn)生價值,我們在追求其視覺表現(xiàn)的同時,更側(cè)重于功能的便捷,營銷的便利,運營的高效,讓網(wǎng)站成為營銷工具,讓軟件能切實提升企業(yè)內(nèi)部管理水平和效率。優(yōu)秀的程序為后期升級提供便捷的支持!
您當(dāng)前位置>首頁 » 新聞資訊 » 小程序相關(guān) >
用 Vue3 開發(fā)小程序,這里有一份實際的代碼案例!
發(fā)表時間:2021-1-5
發(fā)布人:葵宇科技
瀏覽次數(shù):147
前言
尋尋覓覓冷冷清清,凄凄慘慘戚戚。
Vue 3 發(fā)布以后,最近也在學(xué)習(xí)和寫一些 Vue3 的 demo 和項目,我也一直想著什么時候能在小程序里使用新特性?
于是我翻遍了市面上的小程序框架,如 uni-app、wepy、mpvue,目前(截止至2020年11月5日)還都沒能做到兼容 Vue 3 的寫法,直到我發(fā)現(xiàn)了一個很騷的東西, Taro 居然支持 Vue 3。
首先需要全局安裝 @tarojs/cli
:
# 使用 npm 安裝 CLI
$ npm install -g @tarojs/cli
# OR 使用 yarn 安裝 CLI
$ yarn global add @tarojs/cli
# OR 安裝了 cnpm,使用 cnpm 安裝 CLI
$ cnpm install -g @tarojs/cli
如果你的本地已經(jīng)安裝了 @tarojs/cli
,并且版本是 3.x,那么可以忽略上述操作。但是如過你的版本是 2.x,你需要先將它卸載了,再進行上述安裝,卸載如下:
$ npm uninstall -g @tarojs/cli
# 或者
$ yarn global remove @tarojs/cli
必要的話,兩個都執(zhí)行一遍。
這是我的版本號:
初始化項目
通過如下命令行初始化項目:
taro init taro-vue3
選項如下,這里要注意 CSS 預(yù)處理去選擇 Sass,后面 UI 框架會用到:
稍等一會兒,項目便可初始化完畢。
結(jié)束之后進入項目,運行指令:
npm run dev:weapp
編譯成功之后,通過微信開發(fā)者工具打開 dist 目錄,瀏覽項目,如下所示:
UI 庫添加
要開發(fā)一個項目,雖然說不一定非要上 UI 庫,但是有總比沒有好。純手寫樣式當(dāng)然也是考驗一個前端工程師的技術(shù)功底,但是項目工期不等人,提高開發(fā)效率才是第一位。
在我查找 Taro 是否有 Vue 相關(guān)的 UI 庫時,我找到了 taro-ui-vue ,感覺很舒服,應(yīng)該很快就可以寫出一個 demo 來。
后來安裝好組件包,引入組件使用的時候,編譯出錯了,大概看了一下,是沒有兼容 Vue 3 的寫法。
于是我打算暫時放棄了,然后到 taro-ui-vue 的倉庫里提了一個 Issue,如下所示:
我再一次沸騰了,居然還有這玩意兒 taro-ui-vue3 ,此時此刻我突然就很想和東哥做兄弟,哈哈哈哈。
繼續(xù)整!我們可以在項目里通過 npm install taro-ui-vue3
添加組件包,根據(jù)官網(wǎng)的提示,我這里采用了樣式全局引入的方式:
// app.js
import { createApp } from 'vue'
import store from './store'
import 'taro-ui-vue3/dist/style/index.scss'
const App = createApp({
onShow (options) {},
// 入口組件不需要實現(xiàn) render 方法,即使實現(xiàn)了也會被 taro 所覆蓋
})
App.use(store)
export default App
頁面中直接通過引入組件使用:
<template>
<view class="index">
<NumberDisplay/>
<NumberSubmit/>
<AtButton class="add-btn" type='primary'>測試AtButton>
view>
template>
<script>
import NumberDisplay from '../../components/NumberDisplay.vue'
import NumberSubmit from '../../components/NumberSubmit.vue'
import { AtButton } from 'taro-ui-vue3'
export default {
name: 'Index',
components: {
NumberDisplay,
NumberSubmit,
AtButton
}
}
script>
<style>
.index {
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>
如下圖所示:
更多組件使用,請自行查閱 taro-ui-vue3
官方文檔 。
最后
本文主要就是為了安利大家一個能用 Vue 3 語法寫小程序的框架,在此我也基于上述代碼實踐了一下,制作了一個 TodoList 小案例:
源代碼已經(jīng)開源到 GitHub vue3-examples 倉庫中,倉庫地址: vue3-examples ,此倉庫將不定期更新各種 Vue3.0 相關(guān)的知識及各種整合 Demo 及 Vue3 使用小技巧,大家可以關(guān)注一下,有什么建議也歡迎大家給我留言。
相關(guān)案例查看更多
相關(guān)閱讀
- 小程序密鑰
- 云南企業(yè)網(wǎng)站
- 汽車回收管理系統(tǒng)
- 網(wǎng)絡(luò)公司電話
- 小程序技術(shù)
- 保山小程序開發(fā)
- 網(wǎng)站建設(shè)選
- 前端開發(fā)
- web
- 網(wǎng)站建設(shè)首選
- 云南網(wǎng)站建設(shè)選
- 跳轉(zhuǎn)小程序
- 云南小程序商城
- 智慧農(nóng)貿(mào)市場
- 網(wǎng)站建設(shè)價格
- 網(wǎng)站優(yōu)化
- 高端網(wǎng)站建設(shè)公司
- 文山小程序開發(fā)
- 分銷系統(tǒng)
- 云南小程序開發(fā)制作
- 云南網(wǎng)站建設(shè)外包
- 網(wǎng)站維護
- 微信分銷系統(tǒng)
- web學(xué)習(xí)路線
- 網(wǎng)絡(luò)營銷
- 云南軟件定制公司
- 云南小程序被騙
- 企業(yè)網(wǎng)站
- 網(wǎng)站沒排名
- web教程