飞道的博客

Vue | Vue.js Composition API(二)

404人阅读  评论(0)

🖥️ Vue.js专栏:Vue.js 初级知识 Composition API(二)
🧑‍💼 个人简介:一个不甘平庸的平凡人🍬

✨ 个人主页:CoderHing的个人主页

🍀 格言: ☀️ 路漫漫其修远兮,吾将上下而求索☀️

👉 你的一键三连是我更新的最大动力❤️


目录

一、computed函数使用

computed

setup中使用ref

二、组件的生命周期函数

生命周期钩子

三、Provide/Inject使用

Provide函数

inject函数

数据的响应式

四、watch/watchEffect

侦听数据的变化

Watch的使用

侦听多个数据源

watch的选项

watchEffect

watchEffect的停止侦听

五、自定义HOOK练习

useCounter

useScrollPosition

六、script setup语法糖

Script setup语法

顶层的绑定会被暴露给模板

导入的组件直接使用

defineProps()和defineEmits()

defineExpose()


一、computed函数使用

computed

计算属性computed:当我们的某些属性是依赖其他状态时 可以使用计算属性处理

        在前面的Options API中 我们是使用computed选项来完成的

        在Composition API中 我们可以在setup函数中使用computed方法来编写一个计算属性;

如何使用computed?

        方式一: 接收一个getter函数 并为getter函数返回值 返回一个不变的ref对象

        方式二: 接收一个具有get 和 set的对象 返回一个可变的(可读写的)ref对象

JavaScript
const fullName = computed(()=>{
  return names.firstName + " " + names.lastName
})

 

setup中使用ref

在setup中如何使用ref获取元素或者组件?

        我们只需要定义一个ref对象,绑定到元素或组件的ref属性上即可; 

 

二、组件的生命周期函数

生命周期钩子

前面说过setup可以替代data methods ...这些选项 也可以替代 生命周期钩子(函数)

那么setup中如何使用生命周期函数呢?

        可以使用直接导入的onXX函数注册生命周期钩子

 

三、Provide/Inject使用

Provide函数

在Composition API也可以替代之前的Provide和Inject的选项

我们可以通过provide来提供数据:

        通过provide方法来定义每个Property

provide可以传入两个参数:

        Name: 提供的属性名称

        Value: 提供的属性值

JavaScript
const name = ref("xiong")

provide("name",name)
provide("age",18)

inject函数

在 后代组件 中可以通过 inject 来注入需要的属性和对应的值

        可以通过 inject 来注入需要的内容

inject可以传入两个参数:

        要inject的property的name;

        默认值

JavaScript
const name = inject("name")
const age = inject("age")
const height = inject("height",1.88)

数据的响应式

        为了增加 provide值和inject值之间的响应性,可以在provide值时使用ref和reactive

JavaScript
// 使用 ref 或者 reactive
const name = ref("xiong")

provide("name",name)
provide("age",18)

四、watch/watchEffect

侦听数据的变化

在Options API中,我们可以通过 watch选项 侦听 data或props的数据变化,当数据变化时 执行某一些操作.

在Composition API中 我们可以使用 watchEffect和watch来完成响应式数据的侦听

        watchEffect:用于自动收集响应式数据的依赖

        watch:需要手动指定侦听的数据源

Watch的使用

watch的API完全等同于组件的watch选项:

        watch需要 侦听特定的数据源,并且执行其回调函数

        默认情况下,它是惰性的,只有当侦听的源发生变化时 才会执行回调

侦听多个数据源

侦听器可以使用数组同时侦听多个源:

watch的选项

如果希望侦听一个深层的侦听,需要设置deep为true 也可以传入 immediate 立即执行

JavaScript
const info = reactive({
  name:"xiong",
  age:18
})

//  默认绑定 深度侦听
watch(info,(newValue,oldValue)=>{
  console.log(newValue,oldValue)
},{
  immediate:true // 默认执行一次侦听
})

// 侦听reactive 数据变化后,获取普通对象
//  内部 执行 () =>info 这个函数 收集依赖
//  这样 就可以给我们普通对象了
watch(()=> ({...info}),(newValue,oldValue)=>{
  console.log(newValue,oldValue)
},{
  immediate:true,
  deep:true
})

watchEffect

当侦听到某些响应式数据发生变化时 希望执行某些操作 这个时候可以使用watchEffect

        watchEffect传入的函数会立即执行一次,并且在执行的过程中会收集依赖

        只有收集的依赖发生变化时 watchEffect传入的函数才会再次执行

JavaScript
const counter = ref(0)
const names = ref("xiong")

// 1 watchEffect 传入 回调函数 默认 会被自动执行
// 2 在执行的过程中,会自动的收集依赖(依赖哪些响应式的数据 就收集哪些)
watchEffect(()=>{
  console.log("-----------",counter.value,names.value)
})

watchEffect的停止侦听

JavaScript
// 当我们的counter达到时的时候 我想要停止监听 怎么实现?
//  watchEffect 是有返回值的
// 实现了
const stopWatch = watchEffect(()=>{
  console.log("-----------",counter.value,names.value)
//  再里面进行判断  counter.value>10
  if(counter.value >= 10){
    stopWatch()
  }
})

五、自定义HOOK练习

useCounter

 

useTitle

useScrollPosition

获取当前window的滚动位置

 

六、script setup语法糖

Script setup语法

<script setup>是在单文件组件(SFC)中使用组合式API的编译时语法糖,当同时使用SFC与组合式API时则推荐该语法.

        更少的样板内容,更简洁的代码.

        能够使用纯Typescript声明prop和抛出事件

        更好的运行时性能

        更好的IDE类型推断性能

使用这个语法 将setup attribute 添加到 <script>代码块上:

JavaScript
<script setup>

  const msg = "Hello World"

</script>

里面的代码会被编译成组件setup()函数的内容:

        意味着与普通的script标签 只在组件被首次引入的时候执行一次不同;

        <script setup>中的代码会在每次组件实例被创建的时候执行

顶层的绑定会被暴露给模板

当使用<script setup>的时候,任何在<script setup>声明的顶层的绑定(包括变量,函数声明,及import引入的内容)都能在模板中直接使用:

响应式数据需要通过ref reactive来创建

导入的组件直接使用

<script setup范围里的值也能被直接作为自定义组件的标签名使用:

JavaScript
<template>
  <show-info></show-info>
</template>

<script setup>
import ShowInfo from './ShowInfo'
</script>

defineProps()和defineEmits()

为了在声明props和emits选项时 获得完整的类型推断支持,我们可以使用defineProps和defineEmits API 它们将自动地在<script setup>中可用

JavaScript
<script setup>
  // 定义props defineProps接收  定义属性
  const props = defineProps({
    name:{
      type:String,
      default:"默认值"
    },
    age:{
      type:Number,
      default:0
    }
  })
  // 绑定函数,并且发出事件
  // emits
  // 定义 emits  返回一个东西给 emits
    const emits = defineEmits(["showInfoBtnClick"])
    function showInfoBtnClick(){
      // 调用 emits这个函数
      emits("showInfoBtnClick","showInfo内部发生了点击")
    }

</script>

// APP中
<show-info name="xiong"
           :age="18"
            @showInfoBtnClick="showInfoBtnClick">
</show-info>

defineExpose()

使用<script setup>的组件是默认关闭的:

        通过模板 ref 或$parent 链 获取到的组件的公开实例,不会暴露任何在<script setup>中声明的绑定.

通过defineExpose编译器 宏来显示指定在<script setup>组件中要暴露出去的property

JavaScript
    function foo(){
      console.log("foo function")
    }

    defineExpose({
      foo
    })


转载:https://blog.csdn.net/coderHing/article/details/127707762
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场