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

前端vue3?setup使用教程

 更新時間:2022年02月19日 16:26:36   作者:悟世君子  
這篇文章主要為大家介紹了前端vue3架構(gòu)setup使用教程,詳細介紹?setup?的用法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

vue3 中新增了 setup,它的出現(xiàn)是為了解決組件內(nèi)容龐大后,理解和維護組件變得困難的問題。即 vue 中 data、computed、methods、watch 等內(nèi)容非常多以后,同一業(yè)務(wù)邏輯的 data 中的數(shù)據(jù)和 methods 中的方法在 vue 文件中“相隔甚遠”,看代碼時,經(jīng)常需要根據(jù) data 中的數(shù)據(jù)去搜索找到對應(yīng)的 methods 方法,上下跳躍查看代碼,非常不方便。而在 setup 中,則可以把 data 中的數(shù)據(jù)和 methods 方法寫在相臨的位置,方便查看和維護。

1、簡單使用

先簡單寫一下看看效果

筆者這里使用新建的 vue3 項目,直接在 App.vue 上進行修改

<template>
  <div>{{name}}</div>
</template>
 
<script>
export default {
  setup() {
    return {
      name: "淚眼問花花不語,亂紅飛過秋千去"
    }
  }
}
</script>

原來寫在 data 中的 name,在 setup 中需要 return 返回

運行效果

2、修改 setup 中的變量值

先看下面代碼,再說在 setup 中如何修改

<template>
  <div>
    {{name}}
    <button @click="change">修改</button>
  </div>
</template>
 
<script>
export default {
  setup() {
    let name = "淚眼問花花不語,亂紅飛過秋千去"
    function change() {
      name = "人生自是有情癡,此恨不關(guān)風與月"
    }
    return {
      name,
      change
    }
  }
}
</script>

按照常規(guī)邏輯,修改 setup 中的 name,會自然地寫出上面的代碼

但是這段代碼是不能完成 name 值的修改的,看運行效果

為什么 name 值沒有改變呢?因為上面代碼中 name 是非響應(yīng)式的

如果想要修改 name 值,就需要把它改成響應(yīng)式的,代碼如下

<template>
  <div>
    {{name}}
    <button @click="change">修改</button>
  </div>
</template>
<script>
import { ref } from 'vue'
export default {
  setup() {
    let name = ref("淚眼問花花不語,亂紅飛過秋千去")
    function change() {
      name.value = "人生自是有情癡,此恨不關(guān)風與月"
    }
    return {
      name,
      change
    }
  }
}
</script>

使用 ref 對 name 進行包裝

修改時使用 變量名.value 的語法

運行效果

除了使用 ref 外還可以使用 reactive ,二者都可以將原始數(shù)據(jù)類型轉(zhuǎn)換成一個帶有響應(yīng)式特性的數(shù)據(jù)類型

ref 和 reactive 有什么區(qū)別,ref 一般處理基本類型;reactive 處理復雜的數(shù)據(jù)類型

reactive 使用代碼

<template>
  <div>
    {{nameObj.name}}
    <button @click="change">修改</button>
  </div>
</template>
 
<script>
import {reactive} from 'vue'
export default {
  setup() {
    let nameObj = reactive({name: '今年花勝去年紅??上髂昊ǜ茫c誰同'})
    function change() {
      nameObj.name = "離愁漸遠漸無窮,迢迢不斷如春水"
    }
    return {
      nameObj,
      change
    }
  }
}
</script>

運行效果

3、setup 形式下的父子組件通信

代碼寫成 setup 形式,如何實現(xiàn)父子組件通信,下面介紹

3.1、父傳子

在 components 目錄下新建 Article.vue 作為子組件

Article.vue 內(nèi)容

<template>
  <div>
    {{msg}}
    {{info}}
  </div>
</template>
 
<script>
export default {
  props:['msg'],
  setup(props) {
    console.log(props.msg)
 
    return {
      info:props.msg
    }
  }
}
</script>

在 setup 方法內(nèi)使用 props 來接收父組件傳過來的數(shù)據(jù)

App.vue 為父組件

在 App.vue 中引入 Article.vue

<template>
  <div>
    <Article :msg="name"></Article>
  </div>
</template>
 
<script>
import Article from '@/components/Article.vue' 
export default {
  components: {
    Article
  },
  setup() {
    return {
      name: '漸行漸遠漸無書,水闊魚沉何處問'
    }
  }
}
</script>

運行效果

3.2、子傳父

3.2.1、子組件調(diào)用父組件方法

Article.vue 內(nèi)容

<template>
  <div>
    {{msg}}
    <button @click="sendToParent">子組件向父組件傳遞數(shù)據(jù)</button>
  </div>
</template>
 
<script>
export default {
  props:['msg'],
  setup(props, content) {
    console.log(props.msg)
    function sendToParent() {
      content.emit('change')
    }
    return {
      sendToParent
    }
  }
}
</script>

使用 setup 方法中 content 參數(shù)中的 emit

App.vue 內(nèi)容

<template>
  <div>
    <Article :msg="name" @change="changeName"></Article>
  </div>
</template>
<script>
import Article from '@/components/Article.vue' 
export default {
  components: {
    Article
  },
  setup() {
    function changeName() {
      alert('父組件事件被調(diào)用')
    }
    return {
      name: '漸行漸遠漸無書,水闊魚沉何處問',
      changeName
    }
  }
}
</script>

運行效果

3.2.2、子組件向父組件傳遞數(shù)據(jù)

子組件向父組件傳遞數(shù)據(jù),父組件修改數(shù)據(jù)

Article.vue 內(nèi)容

<template>
  <div>
    {{msg}}
    <button @click="sendToParent">子組件向父組件傳遞數(shù)據(jù)</button>
  </div>
</template>
<script>
export default {
  props:['msg'],
  setup(props, content) {
    console.log(props.msg)
    let newName = '群芳過后西湖好,狼籍殘紅。飛絮濛濛。垂柳闌干盡日風'
    function sendToParent() {
      content.emit('change', newName)
    }
    return {
      sendToParent
    }
  }
}
</script>

App.vue 內(nèi)容

<template>
  <div>
    <Article :msg="name" @change="changeName"></Article>
  </div>
</template>
<script>
import Article from '@/components/Article.vue' 
import {ref} from 'vue'
export default {
  components: {
    Article
  },
  setup() {
    let name = ref('漸行漸遠漸無書,水闊魚沉何處問')
    function changeName(msg) {
      name.value = msg
    }
    return {
      name,
      changeName
    }
  }
}
</script>

App.vue 中的 name 要修改,所以使用 ref 包裝

運行效果

 4、setup 中使用生命周期函數(shù)

在 setup 里,生命周期鉤子前面加上 “on” 來訪問組件的生命周期鉤子

setup 是圍繞 beforeCreate 和 created 生命周期鉤子運行的,所以不需要顯式地定義它們

setup 內(nèi)部調(diào)用生命周期鉤子

代碼示例

<template>
  <div></div>
</template>
<script>
import { onBeforeMount, onMounted } from "vue"
export default {
  setup() {
    onBeforeMount(()=>{
      console.log('onBeforeMount')
    })
    onMounted(()=>{
      console.log('mouted')
    })
    return {}
  }
}
</script>

運行效果

以上就是前端vue3架構(gòu)setup使用教程的詳細內(nèi)容,更多關(guān)于vue3 setup教程的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解Vue如何支持JSX語法

    詳解Vue如何支持JSX語法

    這篇文章主要介紹了詳解Vue如何支持JSX語法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • 淺析Vue 和微信小程序的區(qū)別、比較

    淺析Vue 和微信小程序的區(qū)別、比較

    寫了vue項目和小程序,發(fā)現(xiàn)二者有許多相同之處,在此想總結(jié)一下二者的共同點和區(qū)別,需要的朋友可以參考下
    2018-08-08
  • 3分鐘讀懂移動端rem使用方法(推薦)

    3分鐘讀懂移動端rem使用方法(推薦)

    這篇文章主要介紹了rem使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • 基于vue-cli 打包時抽離項目相關(guān)配置文件詳解

    基于vue-cli 打包時抽離項目相關(guān)配置文件詳解

    下面小編就為大家分享一篇基于vue-cli 打包時抽離項目相關(guān)配置文件詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue3 Vite 進階rollup命令行使用詳解

    vue3 Vite 進階rollup命令行使用詳解

    這篇文章主要介紹了vue3 Vite 進階rollup命令行使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 解決vue項目nginx部署到非根目錄下刷新空白的問題

    解決vue項目nginx部署到非根目錄下刷新空白的問題

    今天小編就為大家分享一篇解決vue項目nginx部署到非根目錄下刷新空白的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue中input獲取光標位置并追加內(nèi)容

    vue中input獲取光標位置并追加內(nèi)容

    這篇文章主要給大家介紹了關(guān)于vue中input獲取光標位置并追加內(nèi)容的相關(guān)資料,vue通過當前的光標來進行插值,從而需要去獲取光標所在的位置,需要的朋友可以參考下
    2023-07-07
  • vscode配置vue下的es6規(guī)范自動格式化詳解

    vscode配置vue下的es6規(guī)范自動格式化詳解

    這篇文章主要介紹了vscode配置vue下的es6規(guī)范自動格式化詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • element input輸入框自動獲取焦點的實現(xiàn)

    element input輸入框自動獲取焦點的實現(xiàn)

    本文主要介紹了element input輸入框自動獲取焦點的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • Vue3實現(xiàn)動態(tài)面包屑的代碼示例

    Vue3實現(xiàn)動態(tài)面包屑的代碼示例

    這篇文章主要給大家介紹一下Vue3動態(tài)面包屑是如何實現(xiàn)的,實現(xiàn)思路又是什么,以及發(fā)給大家介紹一下面包屑的功能,文章通過代碼示例介紹的非常詳細,需要的朋友可以參考下
    2023-07-07

最新評論