电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

vue3.0 上手體驗

瀏覽:22日期:2022-11-19 16:19:20

vue3.0 beta 版本已經發布有一陣子了,是時候上手體驗一波了~

注意,本文所有演示都是基于 vue3.0 beta 版本,不保證后續正式版 api 不改動。等官方文檔出來后,以官網為準。

環境搭建

直接使用腳手架,如果本地沒有安裝的可以執行腳手架安裝命令:

npm install -g @vue/cli

如果本地安裝過的,可以嘗試更新一下:

npm update -g @vue/cli

測試 vue-cli 版本:

vue -V@vue/cli 4.4.1

接下來創建一個vue項目:

vue create vue3-demo

在出現的命令交互窗口選擇 Manually select features :

Vue CLI v4.4.1? Please pick a preset: 常用配置 (router, vuex, sass, babel, eslint) sass (router, vuex, sass, babel, eslint) test (less, babel, eslint) default (babel, eslint)❯ Manually select features

隨后勾選以下選項,一般開發商業項目都需要這些:

Vue CLI v4.4.1? Please pick a preset: Manually select features? Check the features needed for your project: ◉ Babel ◯ TypeScript ◯ Progressive Web App (PWA) Support ◉ Router ◉ Vuex❯◉ CSS Pre-processors ◉ Linter / Formatter ◯ Unit Testing ◯ E2E Testing

回車后根據自己的習慣選擇好,就開始創建項目。注意這時候還是 vue2 的項目環境,接下來就是升級為 vue3 的運行環境。

升級為 vue3.0 項目

vue-cli 還沒有直接支持 vue3.0,需要依賴插件升級,輸入指令:

cd vue3-demovue add vue-next

執行完上述命令后,會自動安裝 vue-cli-plugin-vue-next 插件,它會將項目升級為 vue3.0 的依賴環境,包括 vue-router 和 vuex 都會升級為 4.x 的版本。

最新版 vue-cli 可以直接創建 vue3 項目了(2020.09更新)

今天將 vue-cli 更新到了 4.5.4 版本,發現可以直接創建 vue3 項目了。使用 vue create vue3-demo 命令創建一個測試項目,會出現以下選項:

vue3.0 上手體驗

可以直接選擇默認的 vue3 配置,也可以選擇最后一項來手動配置,這里演示手動配置,選擇 Manually select features,回車:

vue3.0 上手體驗

根據需要選擇,注意第一項表明了可以選擇 vue 版本,選完后回車:

vue3.0 上手體驗

這里選擇 vue 的版本,直接選擇 3.x 回車即可。這樣就能創建一個基于 vue3 搭建的項目了。

vue3.0 特性體驗

按照上面步驟升級為 vue3.0 項目后,會自動幫我們將一些文件改成 vue3.0 的寫法。

創建vue實例

vue3 創建vue實例不需要使用 new 的方式了,來看 src/main.js 文件:

import { createApp } from ’vue’import App from ’./App.vue’import router from ’./router’import store from ’./store’createApp(App).use(router).use(store).mount(’#app’)

現在是函數式風格來創建vue實例,還記得 vue2 是怎么創建實例的嗎,對比下:

// Vue2 創建實例import Vue from ’vue’import App from ’./App’import router from ’./router’import store from ’./store’new Vue({ el: ’#app’, router, store, render: h => h(App)})

你喜歡哪一種方式?我比較喜歡vue3.0的函數式風格。

路由

看看路由配置文件:src/router/index.js

import { createRouter, createWebHistory } from ’vue-router’import Home from ’../views/Home.vue’const routes = [ { path: ’/’, name: ’Home’, component: Home }, { path: ’/about’, name: ’About’, // route level code-splitting // this generates a separate chunk (about.[hash].js) for this route // which is lazy-loaded when the route is visited. component: () => import(/* webpackChunkName: 'about' */ ’../views/About.vue’) }]const router = createRouter({ history: createWebHistory(process.env.BASE_URL), routes})export default router

這是升級后路由配置方法,可以看到與 vue2 版本有很大的區別。現在創建路由實例需要手動引入 createRouter 方法,創建 history 模式路由也需要手動引入 createWebHistory 方法,這達到 Tree-Shaking 的目的,即不會把所有的 api 都打包進來,只會打包你用到的 api,vue3 將都會使用這種形式。

響應式數據、methods、watch 和 computed

這里應該是改動最大的部分,也是爭議最大的部分,來看看怎么回事。

在vue2版本中,我們聲明響應式數據是這樣的:

// Vue2export default { // .... data() { return { state: { count: 0 } }; },}

在vue3.0中,需要這樣:

// Vue3import { ref } from ’vue’export default { setup () { const count = ref(0) // 聲明 count,初始值為 0 const str = ref(’hello’) // 聲明 str,初始值為 ’hello’ return { count, str } }}

我們要先引入 ref 方法,然后使用它來聲明響應式變量。重要的是,這些操作需要在 setup 函數中進行,而且添加 methods,watch 和 computed 都需要在 setup 中進行。這就跟在vue2中有很大的不同,vue2中我們是使用選項的方式來創建 data、methods、watch 和 computed 的。

接下來演示一個計數器的功能,結合 methods、watch 和 computed:

<template> <div class='home'> <p>count: {{count}}</p> <p>doubleCount: {{doubleCount}}</p> <button @click='add'>增加</button> </div></template><script>import { ref, watch, computed } from ’vue’export default { setup () { // 聲明 count 變量,初始值為 0 const count = ref(0) // 定義 add 方法 const add = () => { count.value++ } // 定義 watch,需要手動引入 watch 方法 watch( () => count.value, (val, oldVal) => { console.log(`new count: ${val},old count: ${oldVal}`) } ) // 定義computed,同樣需要手動引入 computed 方法 const doubleCount = computed(() => count.value * 2) return { count, add, doubleCount } }}</script>

來看這個例子,首先定義方法是可以直接定義在 setup 函數中的,然后 return 出去即可,不知可否注意到在方法里訪問 count 時,是使用 .value 方法訪問的,這里要強調一下,在 setup 中訪問已聲明的響應式變量時,需要使用 .value 方式訪問,包括在 watch 和 computed 中。

接下來是定義 watch,需要手動引入 watch 方法,這也是達到了 Tree-Shaking 的目的,使用到什么就引入什么,最后打包也只打包用到的 api,后面的 computed 也同理。

watch方法有兩個參數,都是函數,第一個函數返回要監聽的值,第二個函數是回調函數,它兩個參數分別表示新值和舊值。

computed 方法返回計算過的值,最后需要 return 出去。用法如上,還是比較好理解的。

你也可以這樣聲明響應式數據(使用 reactive)

前面說到聲明響應式數據,需要使用 ref,其實你也可以使用 reactive 來一次聲明多個變量,下面例子:

<template> <div class='home'> <p>str: {{state.str}}</p> <p>count: {{state.count}}</p> <button @click='add'>增加</button> </div></template><script>import { reactive } from ’vue’export default { setup () { // 引入 reactive,同時定義多個變量 const state = reactive({ count: 0, str: ’hello’ }) // 現在訪問變量,不能使用 .value 方式訪問了 const add = () => { // state.count.value++ // 錯誤 state.count++ } return { state, add } }}</script>

reactive 和 ref

上面說到 ref 和 reactive,這里再簡單說說。reactive 是接收一個普通對象,返回該對象的響應式代理,它等同于 2.x 中的 Vue.observable()。

const obj = reactive({ count: 0 })// obj 此時是一個響應式的對象// 訪問或修改,直接基于 obj.count

ref 也是接收一個參數并返回一個響應式且可改變的 ref 對象,一般參數是基礎類型,比如數值或字符串等。如果傳入的參數是一個對象,將會調用 reactive 方法進行深層響應轉換。ref 對象擁有一個指向內部值的單一屬性 .value,即當你要訪問它的值時,需要 .value 拿到它的值。但是如果是在 setup 中返回且用到模板中時,在 {{}} 里不需要加 .value 訪問,在返回時已經自動解套。

<template> <div>{{ count }}</div></template><script> export default { setup() { return { count: ref(0), // 這里返回,在模板中無需 .value 訪問值 } }, }</script>

獲取路由信息

vue3.0 中使用 getCurrentInstance 方法獲取當前組件實例,然后通過 ctx 屬性獲取當前上下文,ctx.$router 是路由實例,而 ctx.$router.currentRoute 就包含當前路由信息。

<script>import { getCurrentInstance } from ’vue’export default { setup () { const { ctx } = getCurrentInstance() console.log(ctx.$router.currentRoute.value) }}</script>

vuex

查看文件 src/store/index.js:

import Vuex from ’vuex’export default Vuex.createStore({ state: { }, mutations: { }, actions: { }, modules: { }})

發現創建 store 實例的方式改變了,vue2 中是使用 new 的方式:

// Vue2 中創建 store 實例export default new Vuex.Store({ // ... })

一個小例子演示 vue3.0 中使用 store。

創建 store:

import Vuex from ’vuex’export default Vuex.createStore({ state: { count: 0 }, mutations: { ADD (state) { state.count++ } }, actions: { add ({ commit }) { commit(’ADD’) } }, modules: { }})

組件中使用 store:

<template> <div class='home'> <p>{{count}}</p> <button @click='add'>增加</button> </div></template><script>import { computed } from ’vue’import { useStore } from ’vuex’export default { setup () { const store = useStore() const count = computed(() => store.state.count) const add = () => { store.dispatch(’add’) } return { count, add } }}</script>

可以看到 vuex 的 api 基本沒變化,只是在組件中使用時需要引入 useStore 方法返回 store 實例,其實你也可以在當前組件上下文中獲取 store,如下:

import {getCurrentInstance} from ’vue’// ...const store = getCurrentInstance().ctx.$store

大概就記錄到這吧,基本涵蓋到了日常使用的方面。等待 vue3.0 的正式版吧。(還是那句話,上面所講只是基于目前 vue3.0 beta 版本,不保證后續 api 不改動,等正式版官方文檔吧)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 穿线管|波纹穿线管|包塑金属软管|蛇皮管?闵彬专注弱电工程? | 展厅设计公司,展厅公司,展厅设计,展厅施工,展厅装修,企业展厅,展馆设计公司-深圳广州展厅设计公司 | 2025世界机器人大会_IC China_半导体展_集成电路博览会_智能制造展览网 | 专业生产动态配料系统_饲料配料系统_化肥配料系统等配料系统-郑州鑫晟重工机械有限公司 | 福建成考网-福建成人高考网 | 武汉天安盾电子设备有限公司 - 安盾安检,武汉安检门,武汉安检机,武汉金属探测器,武汉测温安检门,武汉X光行李安检机,武汉防爆罐,武汉车底安全检查,武汉液体探测仪,武汉安检防爆设备 | 酵素生产厂家_酵素OEM_酵素加盟_酵素ODM_酵素原料厂家_厦门益力康 | 福建自考_福建自学考试网 | 华东师范大学在职研究生招生网_在职研究生招生联展网 | 语料库-提供经典范文,文案句子,常用文书,您的写作得力助手 | 冷却塔厂家_冷却塔维修_冷却塔改造_凉水塔配件填料公司- 广东康明节能空调有限公司 | 定硫仪,量热仪,工业分析仪,马弗炉,煤炭化验设备厂家,煤质化验仪器,焦炭化验设备鹤壁大德煤质工业分析仪,氟氯测定仪 | 北京乾茂兴业科技发展有限公司 | 无刷电机_直流无刷电机_行星减速机-佛山市藤尺机电设备有限公司 无菌检查集菌仪,微生物限度仪器-苏州长留仪器百科 | VOC检测仪-甲醛检测仪-气体报警器-气体检测仪厂家-深恒安科技有限公司 | 北京印刷厂_北京印刷_北京印刷公司_北京印刷厂家_北京东爵盛世印刷有限公司 | 福州甲醛检测-福建室内空气检测_环境检测_水质检测-福建中凯检测技术有限公司 | 开锐教育-学历提升-职称评定-职业资格培训-积分入户 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | 电动垃圾车,垃圾清运车-江苏速利达机车有限公司 | 美能达分光测色仪_爱色丽分光测色仪-苏州方特电子科技有限公司 | 全自动翻转振荡器-浸出式水平振荡器厂家-土壤干燥箱价格-常州普天仪器 | 提升海外网站流量,增加国外网站访客UV,定制海外IP-访客王 | 闭端端子|弹簧螺式接线头|防水接线头|插线式接线头|端子台|电源线扣+护线套|印刷电路板型端子台|金笔电子代理商-上海拓胜电气有限公司 | 臭氧老化试验箱,高低温试验箱,恒温恒湿试验箱,防水试验设备-苏州亚诺天下仪器有限公司 | 冷油器,取样冷却器,热力除氧器-连云港振辉机械设备有限公司 | 神超官网_焊接圆锯片_高速钢锯片_硬质合金锯片_浙江神超锯业制造有限公司 | 化妆品加工厂-化妆品加工-化妆品代加工-面膜加工-广东欧泉生化科技有限公司 | 成都网站建设制作_高端网站设计公司「做网站送优化推广」 | RTO换向阀_VOC高温阀门_加热炉切断阀_双偏心软密封蝶阀_煤气蝶阀_提升阀-湖北霍科德阀门有限公司 | 重庆小面培训_重庆小面技术培训学习班哪家好【终身免费复学】 | 长沙中央空调维修,中央空调清洗维保,空气能热水工程,价格,公司就找维小保-湖南维小保环保科技有限公司 | 双能x射线骨密度检测仪_dxa骨密度仪_双能x线骨密度仪_品牌厂家【品源医疗】 | 大白菜官网,大白菜winpe,大白菜U盘装系统, u盘启动盘制作工具 | 制冷采购电子商务平台——制冷大市场 | 玉米深加工设备-玉米深加工机械-新型玉米工机械生产厂家-河南粮院机械制造有限公司 | 实体店商新零售|微赢|波后|波后合作|微赢集团 | 木材烘干机,木炭烘干机,纸管/佛香烘干设备-河南蓝天机械制造有限公司 | 【ph计】|在线ph计|工业ph计|ph计厂家|ph计价格|酸度计生产厂家_武汉吉尔德科技有限公司 | 土壤检测仪器_行星式球磨仪_土壤团粒分析仪厂家_山东莱恩德智能科技有限公司 | 米顿罗计量泵(科普)——韬铭机械 |