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

无锡大型网站建设公司wordpress single_post_title

无锡大型网站建设公司,wordpress single_post_title,谷歌网站推广好做吗,忽悠别人做商城网站往期内容: 《Vue零基础入门教程》合集(完结) 《Vue进阶教程》第一课:什么是组合式API 《Vue进阶教程》第二课:为什么提出组合式API 《Vue进阶教程》第三课:Vue响应式原理 通过前面的学习, 我们了解到r…

  往期内容:

《Vue零基础入门教程》合集(完结)

《Vue进阶教程》第一课:什么是组合式API

《Vue进阶教程》第二课:为什么提出组合式API

《Vue进阶教程》第三课:Vue响应式原理

通过前面的学习, 我们了解到reactive可以将一个普通对象转换成响应式对象.

那么, 接下来我们就详细研究一下这个函数.

研究函数主要从这样三个方面

  1. 输入, 也就是参数
  2. 作用, 做了什么
  3. 输出, 也就是返回值
  1. 参数: 只能是引用类型数据, 不能是值类型数据
  2. 作用: 创建传入对象的深层代理, 并返回代理后的对象
  3. 返回值: 一个Proxy代理对象

1) 深层代理

不管传入的对象存在多少层嵌套(对象套对象的情况), 每一层都具有响应性

示例

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.global.js"></script></head><body><script>const { reactive, effect } = Vueconst pState = reactive({name: 'xiaoming',age: 20,gf: {name: 'xiaomei',city: {name: 'wuhan',},},})effect(() => {console.log(`${pState.name}的女朋友叫${pState.gf.name}, 在${pState.gf.city.name}`)})setTimeout(() => {console.log('过了一段时间, 她去了beijing')// 不管嵌套多少层, 都具有响应性pState.gf.city.name = 'beijing'}, 1000)</script></body>
</html>

2) 重复代理

  1. 对同一个普通对象, 多次代理, 返回的结果唯一
  2. 对代理后的对象再次代理, 返回的结果唯一

以上, 可以理解为单例模式, reactive创建的代理对象只会存在一个

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.global.js"></script></head><body><script>const { reactive, effect } = Vueconst state = { name: 'xiaoming' }const p1 = reactive(state)const p2 = reactive(state)// 对同一个对象多次代理, 返回的结果唯一console.log(p1 === p2) // trueconst p3 = reactive(p1)// 对代理后的对象, 再次代理, 返回的结果唯一console.log(p3 === p1) // true</script></body>
</html>

3) 局限性

  1. 传入参数只能是对象
  2. 解构或者赋值操作会丢失响应性

示例1

解构赋值后的变量没有响应性

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.global.js"></script></head><body><div id="app"></div><script>const { reactive, effect } = Vueconst pState = reactive({ name: 'xiaoming' })// 对代理对象进行解构let { name } = pStateeffect(() => {app.innerHTML = pState.name})setTimeout(() => {name = 'xiaomei'console.log('对解构后的name操作, 不会触发响应式')}, 1000)</script></body>
</html>

示例2

赋值操作丢失响应性

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.global.js"></script></head><body><div id="app"></div><script>const { reactive, effect } = Vuelet todos = reactive([])effect(() => {app.innerHTML = JSON.stringify(todos)})// 模拟向接口请求setTimeout(() => {// 将接口返回的数据赋值给todos, 导致todos丢失了响应性todos = [{ id: 1, content: 'todo-1' },{ id: 2, content: 'todo-2' },]}, 1000)</script></body>
</html>

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

相关文章:

  • 科技感的网站网站地图怎么弄
  • 南京企业自助建站系统网站建设的收费
  • 门户网站html模板下载如何管理建好的网站
  • 生成flash的网站源码哪些网站可以做移动端模板
  • 集团公司网站怎么做著名网页设计师及作品
  • 国际学校网站建设江苏国家企业信息系统
  • 怎么查网站备案信息做网站小程序
  • error 403 网站拒绝显示开发公司质量管理制度
  • 湖州网站建设培训菏泽软件定制开发
  • 建设微网站项目报告广安网站建设
  • logo免费自动生成器沈阳百度推广排名优化
  • idea怎么做网站wordpress 建单页网站
  • 医药平台网站建设专门做鞋子的网站
  • mcms怎么做网站网上商城网站源码
  • 织梦app网站模板纪检监察网站建设的意义
  • 建设网站需要掌握什么编程语言网页游戏排行榜斗地主
  • 手机网站 软件天华集团设计公司
  • 长春做网站价格重庆包装设计公司
  • 门户网站管理建设回收手表的网站
  • 桂林北站怎么去阳朔北京网络推广外包
  • 企业网站制作公司推荐网站服务器速度查询
  • 南充网站建设略奥标题seo是什么意思
  • 设计网站公司的口号at结尾网站
  • 重庆网站设计重庆最加科技wordpress dns
  • 网站制作模板免费下载asp.net mvc网站发布教程
  • 系统那个网站免费北京sem网站
  • 用flash制作网站在线做网站图标
  • 东莞免费做网站建筑网址导航大全首页
  • 展厅设计的主题搜狗排名优化工具
  • wap建站程序免费下载chrome浏览器官网入口