Vue3 -- 响应式 ref和 reactive

前言

根据某站的vue教学视频,看万卷教程不如敲万行代码,根据教学进度整理对应代码,更快的熟悉这门语言

流程

响应式:简单来说就是浏览器页面触发条件(常见点击按钮)后页面数据动态改变。

按以前的代码

html 复制代码
    //data
    const name = 'kane' 
 
    //methods
    //触发下面方法,页面数据是不会改变的
    function changeName() {
       name = '小伙子'
    } 

按上面function的方法,数据只在后台这边修改了,页面的响应是不会变,也就是的name值不会变化。要达到页面也同步变化要使用ref或者 reactive

ref和 reactive区别

ref是基本数据类型的响应式,reactive是应用类型的响应式

响应式修改实现
ref响应式

Person.vue

html 复制代码
<template>
  <div class="person">
    <h2>姓名:{{ name }}</h2>
    <h2>年龄:{{ age }}</h2>
    <button @click="changeName">改名</button>
    <button @click="changeAge">改年龄</button>
    <button @click="showTel">1查看联系方式</button>
  </div>
</template>

<script lang="ts" setup name="PersonA">
import { ref } from 'vue'
//data 原来是写在data中的,此时的name、age、tel都不是响应式的数据,加ref变成响应式
const name = ref('kane')
const age = ref(18)
const tel = '1223355446'

//methods
function changeName() {
  name.value = '嘿嘿' //加上ref后,这个name就相当于变成了一个实例,我们改的就是这个实例对象的value,所以是修改name.value
  console.log(name.value)
}
function changeAge() {
  age.value += 1
  console.log(age.value)
}
function showTel() {
  alert('kane: ' + tel)
}
</script>

<style>
.app {
  background-color: red;
  box-shadow: 0 0 10px;
  border-radius: 10px;
  padding: 20px;
}
</style>
reactive响应式

Car.vue

html 复制代码
<template>
  <div class="car">
    <h2>汽车信息:一辆{{ car.brand }}车,价值{{ car.price }}万</h2>
    <button @click="changePrice">修改汽车的价格</button>
    <br />
    <h2>游戏列表:</h2>
    <ul>
      <li v-for="g in games" :key="g.id">{{ g.name }}</li>
    </ul>
    <button @click="changeFirstGame">修改第一个游戏的名字</button>
  </div>
</template>

<script lang="ts" setup name="Car">
import { reactive } from 'vue'
//data
const car =   ({ brand: '奔驰', price: 100 })
const games = reactive([
  { id: 'aysdytfsatr01', name: '王者荣耀' },
  { id: 'aysdytfsatr02', name: '原神' },
  { id: 'aysdytfsatr03', name: '三国志' },
])

//methods
function changePrice() {
  car.price += 10
}
function changeFirstGame() {
  games[0].name = '泡泡堂'
}
</script>

<style scoped>
.person {
  background-color: skyblue;
  box-shadow: 0 0 10px;
  border-radius: 10px;
  padding: 20px;
}
button {
  margin: 0 5px;
}
li {
  font-size: 20px;
}
</style>
Persion.vue和Car.vue注册到App.vue

App.vue

html 复制代码
<template>
  <div class="app">
    <h1>hello world</h1>
    <Person></Person>
    <br />
    <br />
    <Car></Car>
  </div>
</template>

<script lang="ts">
import Person from './components/Person.vue'
import Car from './components/Car.vue'

export default {
  name: 'App', //组件名
  components: { Person, Car }, //注册组件名
}
</script>

<style>
.app {
  background-color: #ddd;
  box-shadow: 0 0 10px;
  border-radius: 10px;
  padding: 20px;
}
</style>
启动
html 复制代码
npm run dev
效果

http://localhost:5173/

点击安你要测试,页面是否响应变化

相关推荐
一个博客40 分钟前
pdf-viewer 实现预览pdf文件
开发语言·javascript·pdf
2501_9127840843 分钟前
跨境电商独立站的多语言架构设计:基于 Laravel + Vue.js 的实践
vue.js·php·laravel·跨境电商·taocarts
wuxia21189 小时前
微信小程序单击元素切换元素的显示和隐藏
javascript·微信小程序·setdata
JustHappy9 小时前
古法编程秘籍(二):什么是代码模块化?别背概念,把房间收拾明白就够了
前端·后端
小江的记录本9 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
weixin_471383039 小时前
图片预解码缓存
前端·浏览器缓存·图片预解码
一起学开源9 小时前
一文读懂 ReAct 范式:让 AI Agent 真正学会“思考+行动“
java·javascript·react.js·ecmascript·react·alibaba·智能体开发
岁月宁静11 小时前
驾驭 AI 这匹野马:深入解析智能体 Harness 工程
vue.js·python
郑洁文11 小时前
基于网络爬虫的Web敏感信息泄露自动化检测工具
前端·爬虫·网络安全·自动化
游九尘11 小时前
JavaScript 实现三段式版本号对比函数(app升级用)
javascript·uni-app