组合式API-reactive和ref函数,computed计算属性,watch函数

一.reactive()接收一个对象类型的数据,返回一个响应式的对象:

javascript 复制代码
<script setup>
import {reactive} from 'vue'
const state = reactive({
  count:100
})
const setCount =() => {
  state.count++
}
</script>
<template>
  <div>
    <div>{{ state.count }}</div>
    <button @click="setCount">+1</button>
  </div>
</template>

二.ref()接收简单类型或者对象类型的数据传入并返回一个响应式对象

推荐声明数据,统一用ref

注意:脚本中访问数据,需要通过.value

在template中,.value不需要加(自动扒掉了一层)

javascript 复制代码
<script setup>
import {ref} from 'vue'
const count = ref (0)
const setCount = () => {
  count.value ++
}
</script>
<template>
  <div>{{ count }}</div>
  <button @click="setCount">+1</button>
</template>

三.computed计算属性

const 计算属性 = computed (() => {

return 计算返回的结果

}

javascript 复制代码
<script setup>
import {computed,ref} from 'vue'
const list = ref([
  1,2,3,4,5,6,7,8
])
const computedList = computed(() => {
  return list.value.filter(item => item > 2)
})
</script>

<template>
  <div>
    <div>原始数据:{{ list }}</div>
    <div>计算后数据:{{ computedList }}</div>
  </div>
</template>

增加一个修改函数

javascript 复制代码
<script setup>
import {computed,ref} from 'vue'
const list = ref([
  1,2,3,4,5,6,7,8
])
const computedList = computed(() => {
  return list.value.filter(item => item > 2)
})

const addFn = () =>{
list.value.push(666)
}
</script>

<template>
  <div>
    <div>原始数据:{{ list }}</div>
    <div>计算后数据:{{ computedList }}</div>
  </div>
  <button @click="addFn">修改添加</button>
</template>

注意:计算属性不应该有"副作用",比如异步请求/修改dom

避免直接修改计算属性的值,计算属性应该是只读的,特殊情况可以配置get set

四.watch函数

作用:侦听一个或者多个数据的变化,数据变化时执行回调函数

俩个额外参数:1.immediate(立即执行) 2.deep(深度侦听)

1,侦听单个数据

  • 导入watch函数
  • 执行watch函数传入要侦听的响应式数据(ref对象)和回调函数

watch(ref对象,(newValue,oldValue) => {...} )

javascript 复制代码
<script setup>
import {ref,watch} from 'vue'
const count = ref(0)
const nickname = ref('张三')
const changeCount = () =>{
  count.value++
}
const changeNickname = () =>{
  nickname.value = '李四'
}
//1.监视单个数据变化
// watch(ref对象,(newValue,oldValue) => {...})
watch(count,(newValue,oldValue) => {
  console.log(newValue,oldValue)
})

<template>
  <div>{{ count }}</div>
  <button @lick="changeCount">改数字</button>
  <div>{{ nickname }}</div>
  <button @click="changeNickname">改昵称</button>
</template>

2,侦听多个数据

watch( [ref对象1,ref对象2],(newArr,oldArr) => {...} )

javascript 复制代码
<script setup>
import {ref,watch} from 'vue'
const count = ref(0)
const nickname = ref('张三')
const changeCount = () =>{
  count.value++
}
const changeNickname = () =>{
  nickname.value = '李四'
}
</script>
<template>
  <div>{{ count }}</div>
  <button @lick="changeCount">改数字</button>
  <div>{{ nickname }}</div>
  <button @click="changeNickname">改昵称</button>
</template>
相关推荐
AwesomeCPA1 天前
Miaoduo MCP 使用指南(VDI内网环境)
前端·ui·ai编程
前端大波1 天前
前端面试通关包(2026版,完整版)
前端·面试·职场和发展
qq_433502181 天前
Codex cli 飞书文档创建进阶实用命令 + Skill 创建&使用 小白完整教程
java·前端·飞书
IT_陈寒1 天前
为什么我的Vite热更新老是重新加载整个页面?
前端·人工智能·后端
一袋米扛几楼981 天前
【网络安全】SIEM -Security Information and Event Management 工具是什么?
前端·安全·web安全
小陈工1 天前
2026年4月7日技术资讯洞察:下一代数据库融合、AI基础设施竞赛与异步编程实战
开发语言·前端·数据库·人工智能·python
Cobyte1 天前
3.响应式系统基础:从发布订阅模式的角度理解 Vue2 的数据响应式原理
前端·javascript·vue.js
竹林8181 天前
从零到一:在React前端中集成The Graph查询Uniswap V3池数据实战
前端·javascript
Mintopia1 天前
别再迷信"优化":大多数性能问题根本不在代码里
前端