欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3.0中setup使用(兩種用法)

 更新時(shí)間:2020年12月02日 14:30:53   作者:前端小99  
這篇文章主要介紹了vue3.0中setup使用,本文通過(guò)兩種用法給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一、setup函數(shù)的特性以及作用

  可以確定的是 Vue3.0 是兼容 Vue2.x 版本的 也就是說(shuō)我們?cè)偃粘9ぷ髦?可以在 Vue3 中使用 Vue2.x 的相關(guān)語(yǔ)法 但是當(dāng)你真正開(kāi)始使用 Vue3 寫(xiě)項(xiàng)目時(shí) 你會(huì)發(fā)現(xiàn)他比 Vue2.x 方便的多

  Vue3 的一大特性函數(shù) ---- setup

  1、setup函數(shù)是處于 生命周期函數(shù) beforeCreate 和 Created 兩個(gè)鉤子函數(shù)之間的函數(shù) 也就說(shuō)在 setup函數(shù)中是無(wú)法 使用 data 和 methods 中的數(shù)據(jù)和方法的

  2、setup函數(shù)是 Composition API(組合API)的入口

  3、在setup函數(shù)中定義的變量和方法最后都是需要 return 出去的 不然無(wú)法再模板中使用

二、setup函數(shù)的注意點(diǎn)

  1、由于在執(zhí)行 setup函數(shù)的時(shí)候,還沒(méi)有執(zhí)行 Created 生命周期方法,所以在 setup 函數(shù)中,無(wú)法使用 data 和 methods 的變量和方法

  2、由于我們不能在 setup函數(shù)中使用 data 和 methods,所以 Vue 為了避免我們錯(cuò)誤的使用,直接將 setup函數(shù)中的this修改成了 undefined

  3、setup函數(shù)只能是同步的不能是異步的

用法1:結(jié)合ref使用

<template>
 <div id="app">
  {{name}}
  <p>{{age}}</p>
  <button @click="plusOne()">+</button>
 </div>
</template>
 
<script>
import {ref} from 'vue'
export default {
 name:'app',
 data(){
  return {
   name:'xiaosan'
  }
 },
 setup(){
  const name =ref('小四')
  const age=ref(18)
  function plusOne(){
   age.value++ //想改變值或獲取值 必須.value
  }
  return { //必須返回 模板中才能使用
   name,age,plusOne
  }
 }
}
</script>

用法2:代碼分割

Options API 和 Composition API 

Options API 約定:

我們需要在 props 里面設(shè)置接收參數(shù)

我們需要在 data 里面設(shè)置變量

我們需要在 computed 里面設(shè)置計(jì)算屬性

我們需要在 watch 里面設(shè)置監(jiān)聽(tīng)屬性

我們需要在 methods 里面設(shè)置事件方法

你會(huì)發(fā)現(xiàn) Options APi 都約定了我們?cè)撛谀膫€(gè)位置做什么事,這反倒在一定程度上也強(qiáng)制我們進(jìn)行了代碼分割。

現(xiàn)在用 Composition API,不再這么約定了,于是乎,代碼組織非常靈活,我們的控制代碼寫(xiě)在 setup 里面即可。

setup函數(shù)提供了兩個(gè)參數(shù) props和context,重要的是在setup函數(shù)里沒(méi)有了this,在 vue3.0 中,訪(fǎng)問(wèn)他們變成以下形式: this.xxx=》context.xxx

我們沒(méi)有了 this 上下文,沒(méi)有了 Options API 的強(qiáng)制代碼分離。Composition API 給了我們更加廣闊的天地,那么我們更加需要慎重自約起來(lái)。

對(duì)于復(fù)雜的邏輯代碼,我們要更加重視起 Composition API 的初心,不要吝嗇使用 Composition API 來(lái)分離代碼,用來(lái)切割成各種模塊導(dǎo)出。

我們期望是這樣的:

importuseAfrom'./a';
 
importuseBfrom'./b';
 
importuseCfrom'./c';
 
exportdefault{
 
setup (props) {
 
let{ a, methodsA } = useA();
 
let{ b, methodsB } = useA();
 
let{ c, methodsC } = useC();
 
return{
 
a,
 
methodsA,
 
b,
 
methodsB,
 
c,
 
methodsC
 
}
 
}
 
}

就算 setup 內(nèi)容代碼量越來(lái)越大,但是始終圍繞著大而不亂,代碼結(jié)構(gòu)清晰的路子前進(jìn)。

到此這篇關(guān)于vue3.0中setup使用的文章就介紹到這了,更多相關(guān)vue3.0 setup使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue項(xiàng)目中使用骨架屏的方法

    vue項(xiàng)目中使用骨架屏的方法

    在頁(yè)面加載數(shù)據(jù)之前,有一段空白時(shí)間,要么用loading加載,要么就用骨架屏,本文主要介紹了vue項(xiàng)目中使用骨架屏的方法,感興趣的可以了解一下
    2021-05-05
  • Vue.js 2.0 移動(dòng)端拍照壓縮圖片上傳預(yù)覽功能

    Vue.js 2.0 移動(dòng)端拍照壓縮圖片上傳預(yù)覽功能

    這篇文章主要介紹了Vue.js 2.0 移動(dòng)端拍照壓縮圖片上傳預(yù)覽功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-03-03
  • vue3中實(shí)現(xiàn)使用element-plus調(diào)用message

    vue3中實(shí)現(xiàn)使用element-plus調(diào)用message

    這篇文章主要介紹了vue3中實(shí)現(xiàn)使用element-plus調(diào)用message,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue input輸入框回車(chē)以后自動(dòng)刷新頁(yè)面(直播程序)

    Vue input輸入框回車(chē)以后自動(dòng)刷新頁(yè)面(直播程序)

    這篇文章主要介紹了直播程序,Vue input輸入框回車(chē)以后自動(dòng)刷新頁(yè)面,適用場(chǎng)景是在輸入框輸入字符并按下回車(chē)鍵搜索時(shí),刷新頁(yè)面,需要的朋友參考下實(shí)現(xiàn)代碼
    2023-01-01
  • vue實(shí)現(xiàn)導(dǎo)出Word文件(數(shù)據(jù)流方式)

    vue實(shí)現(xiàn)導(dǎo)出Word文件(數(shù)據(jù)流方式)

    這篇文章主要介紹了vue實(shí)現(xiàn)導(dǎo)出Word文件(數(shù)據(jù)流方式),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue項(xiàng)目中input輸入框輸入不了值問(wèn)題及解決

    vue項(xiàng)目中input輸入框輸入不了值問(wèn)題及解決

    這篇文章主要介紹了vue項(xiàng)目中input輸入框輸入不了值問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 關(guān)于element的表單組件整理筆記

    關(guān)于element的表單組件整理筆記

    這篇文章主要給大家介紹了關(guān)于element的表單組件的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • elementUI中el-dropdown的command實(shí)現(xiàn)傳遞多個(gè)參數(shù)

    elementUI中el-dropdown的command實(shí)現(xiàn)傳遞多個(gè)參數(shù)

    這篇文章主要介紹了elementUI中el-dropdown的command實(shí)現(xiàn)傳遞多個(gè)參數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue3注冊(cè)全局組件的使用方法

    Vue3注冊(cè)全局組件的使用方法

    例如組件使用頻率非常高,幾乎每個(gè)頁(yè)面都在使用便可以封裝成全局組件,下面通過(guò)本文給大家介紹Vue3注冊(cè)全局組件的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2024-01-01
  • defineProperty和Proxy基礎(chǔ)功能及性能對(duì)比

    defineProperty和Proxy基礎(chǔ)功能及性能對(duì)比

    這篇文章主要為大家介紹了defineProperty和Proxy基礎(chǔ)功能及性能對(duì)比,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08

最新評(píng)論