vue3计算属性

77 阅读1分钟

vue3计算属性以及赋值

<template>
    <!-- 计算属性比如分页器就会使用到  -->
    <h1>计算属性</h1> 
    <!-- 此时obj.hobby.length是大于0的,所以页面的list为yes -->
    <h3>{{ list }}</h3>
    <button @click="getList">获取list的值 ==>{{ val }}</button>
</template>
  
<script setup>
import {ref, reactive, computed } from "vue";

// 定义变量obj和val
const obj = reactive({
    todo: '吃饭',
    hobby: ['打篮球', '打乒乓球', '踢足球']
})
// 定义等下需要将list.value赋值给他的变量
const val = ref(null)

// 我们想根据 obj 是否已有一些爱好来展示不同的信息:
// 那么我们就使用计算属性
const list = computed(() => {
    // 用return返回后,list就可以直接使用
    // 使用三元表达式来返回yes或者no,此时obj.hobby.length是大于0的,所以页面的list为yes
    return obj.hobby.length > 0 ? "yes" : 'no'
})

// 当然获取的时候同样也是用.value
const getList = () => {
    console.log(list.value);
    // 赋值给val,并在页面使用
    val.value = list.value
}


</script>