当前位置: 首页 > news >正文

网站改版建设的目的网站配色与布局 教材

网站改版建设的目的,网站配色与布局 教材,网站开发及维护,大朗镇住房规划建设局网站文章目录1. reactive1.1. reactive函数创建一个响应式对象1.2. 修改reactive创建的响应式对象的属性2. readOnly2.1. 使用 readonly 函数创建一个只读的响应式对象2.2. 如何修改嵌套在只读响应式对象中的对象?3. shallowReactive3.1. 使用 shallowReactive 函数创建一个浅层响…

文章目录

  • 1. reactive
    • 1.1. `reactive`函数创建一个响应式对象
    • 1.2. 修改`reactive`创建的响应式对象的属性
  • 2. readOnly
    • 2.1. 使用 `readonly` 函数创建一个只读的响应式对象
    • 2.2. 如何修改嵌套在只读响应式对象中的对象?
  • 3. shallowReactive
    • 3.1. 使用 `shallowReactive` 函数创建一个浅层响应式对象
    • 3.2. 如何修改嵌套在浅层响应式对象中的对象?

1. reactive

  • 实现引用类型数据的响应式,如数组、对象
  • 上一章说到的ref去创建引用类型的响应式,其实内部也是调用了reactive
  • reactive创建的响应式对象,调用时不用.value

在Vue3中,reactive函数是用于创建响应式对象的函数。它接收一个普通对象作为参数,返回一个代理对象。这个代理对象可以拦截对象的getset操作,并在其中实现响应式的逻辑。当我们读取代理对象的属性时,会触发依赖收集;当我们修改代理对象的属性时,会触发相应的依赖更新。在调用reactive函数时,Vue3会使用Proxy对象对传入的对象进行代理,从而实现响应式的特性。

1.1. reactive函数创建一个响应式对象

import { reactive } from 'vue'const state = reactive({count: 0,name: 'Tom'
})console.log(state.count) // 输出 0state.count++console.log(state.count) // 输出 1

在这个例子中,我们使用reactive函数创建了一个响应式对象state,它包含两个属性countname。我们可以直接读取和修改state的属性,不需要使用.value。当我们读取或修改state的属性时,会触发相应的依赖更新。

1.2. 修改reactive创建的响应式对象的属性

import { reactive } from 'vue'const state = reactive({user: {name: 'Tom',age: 18}
})console.log(state.user.name) // 输出 Tomstate.user.name = 'Jerry'console.log(state.user.name) // 输出 Jerry

在这个例子中,我们修改了state对象中嵌套的user对象的name属性。这个修改会触发相应的依赖更新,从而实现了响应式的特性。

2. readOnly

在 Vue 3 中,可以使用 readonly 函数创建一个只读的响应式对象。它接收一个普通对象作为参数,返回一个只读的代理对象。这个代理对象只能读取属性的值,不能修改属性的值。当我们读取代理对象的属性时,会触发依赖收集;当我们尝试修改代理对象的属性时,会输出警告信息,不会触发相应的依赖更新。在调用 readonly 函数时,Vue 3 会使用 Proxy 对象对传入的对象进行代理,从而实现只读的响应式特性。

2.1. 使用 readonly 函数创建一个只读的响应式对象

import { readonly, reactive } from 'vue'const state = readonly(reactive({count: 0,name: 'Tom'
}))console.log(state.count) // 输出 0state.count++ // 输出警告信息,不会触发依赖更新console.log(state.count) // 输出 0

注意:使用 readonly 函数创建的只读响应式对象是深层只读的。也就是说,当我们尝试修改嵌套在只读响应式对象中的对象时,会输出警告信息,不会触发相应的依赖更新。

2.2. 如何修改嵌套在只读响应式对象中的对象?

  • 使用readOnly函数创建的只读对象,内部的属性无法修改
import { readonly, reactive } from 'vue'const state = readonly(reactive({user: {name: 'Tom',age: 18}
}))console.log(state.user.name) // 输出 Tomstate.user.name = 'Jerry' // 输出警告信息,不会触发依赖更新console.log(state.user.name) // 输出 Tom

在这个例子中,我们尝试修改只读响应式对象 state 中嵌套的 user 对象的 name 属性。这个修改会输出警告信息,不会触发相应的依赖更新,从而实现了只读响应式的特性。在实际开发中,readonly 函数是非常有用的一个函数,可以帮助我们创建只读的响应式数据。

3. shallowReactive

  • 创建浅层响应式对象
  • 修改内部属性时,只改变值不更新视图

在 Vue 3 中,可以使用 shallowReactive 函数创建一个浅层响应式对象。它接收一个普通对象作为参数,返回一个浅层响应式代理对象。这个代理对象只能处理对象的一级属性,不能处理嵌套在对象中的属性的响应式更新。当我们读取代理对象的属性时,会触发依赖收集;当我们修改代理对象的属性时,会触发相应的依赖更新。在调用 shallowReactive 函数时,Vue 3 会使用 Proxy 对象对传入的对象进行代理,从而实现浅层响应式特性。

3.1. 使用 shallowReactive 函数创建一个浅层响应式对象

import { shallowReactive } from 'vue'const state = shallowReactive({user: {name: 'Tom',age: 18}
})console.log(state.user.name) // 输出 Tomstate.user.name = 'Jerry'console.log(state.user.name) // 输出 Jerrystate.user = {name: 'Lucy',age: 20
}console.log(state.user.name) // 输出 Lucystate.user.name = 'Lily'console.log(state.user.name) // 输出 Lily

在这个例子中,我们使用 shallowReactive 函数创建了一个浅层响应式对象 state,包含一个属性 user,它是一个普通对象。当我们修改 stateuser 属性时,会触发相应的依赖更新;当我们修改 user 对象的属性时,不会触发相应的依赖更新。

3.2. 如何修改嵌套在浅层响应式对象中的对象?

  • 可以直接修改,但是只更新值,不更新视图
import { shallowReactive } from 'vue'const state = shallowReactive({user: {profile: {name: 'Tom',age: 18}}
})console.log(state.user.profile.name) // 输出 Tomstate.user.profile.name = 'Jerry'console.log(state.user.profile.name) // 输出 Jerry

在这个例子中,我们尝试修改浅层响应式对象 state 中嵌套的 user 对象的 profile 属性中的 name 属性。这个修改不会触发相应的依赖更新,从而实现了浅层响应式的特性。

总结:这篇文章介绍了Vue3中用于创建响应式对象的三个函数:reactivereadonlyshallowReactivereactive函数用于创建深层响应式对象,readonly函数用于创建深层只读响应式对象,shallowReactive函数用于创建浅层响应式对象。这些函数可以帮助我们快速创建响应式数据,实现数据的自动更新。

http://www.yayakq.cn/news/682564/

相关文章:

  • 网站后台程序和数据库开发搜狗搜索引擎优化指南
  • 学校网站建设情况寿光网站建设公司
  • 重庆建站热点新闻头条
  • 各国网站建设排名免费平面设计模板网站
  • 河北省建设工程网站框架型网页布局图片
  • 网站建设公司考察合肥网站建设公司
  • 长春专业做网站公司西峡微网站开发
  • 店面设计图自己怎样优化网站
  • 网站设计 中国风sem推广和seo的区别
  • 建设工程鲁班奖公示网站做网站平台的公司有哪些
  • 手机微网站二级菜单怎么做中山网站建设sipocms
  • 男女做那个什么的视频网站手机上做网站php
  • seo站长优化工具网站建设的对比分析
  • 网站备案取消接入jpress wordpress对比
  • 网络营销是什么岗位wordpress站群怎么优化
  • 功能型网站介绍开发公司工程部职责
  • 用.cc做网站官网可以吗品牌设计公司主营
  • win10做网站服务器wordpress解决新浪图床
  • 网站运营需要多少钱南宁网站建设费用
  • python网站开发流程图网站建设费用推荐网络
  • 怎么自己做网站推广国外 网站 模板
  • 做室内3d设计的网站通过php获取手机网站访客的手机号码
  • 做个app需要多少费用sem和seo的工作
  • 做视频免费模板下载网站重庆建站多少钱一年
  • 如何做好高端品牌网站建设山东省住房城乡建设厅查询网站首页
  • 北京给公司做网站多少钱北京门户网站制作
  • 丽江古城区建设局网站移动互联网论文5000字
  • 西部数码网站站点做网站给源码吗
  • 加强网站备案管理专项行动竞价推广账户托管服务
  • 移动wap网站大连公司