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

行业网站的优势wordpress文章调用函数

行业网站的优势,wordpress文章调用函数,wordpress产品布局,福州开发网站公司往期内容: 《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/737214/

相关文章:

  • 涿州做网站建设怎么做微商网站
  • 专业专题网站建设创意设计报告模板
  • 江苏建设厅官方网站今天广西紧急通知最新
  • 中国印花图案设计网站制作一个手机app需要多少钱
  • 深圳注册公司在什么网站网页设计搜题软件
  • 个人域名 公司网站关于门户网站建设的请示
  • 网站的设计与制作河南金建建设集团网站
  • 个人怎么做微信公众号和微网站小程序开发者
  • 运城做网站的公司短视频培训要多少学费
  • 项目网站建设应入哪个科目蒙牛官网网站怎么做的
  • 徐州网站制作怎么做推广软文营销案例
  • 酒店网站建设方案策划网站设计建设服务
  • 没有公司自己做网站哈尔滨网络公司如何
  • 网站pc转移动端代码织梦网站模板视频
  • 做网站做得好的公司有营销型网站有哪些
  • 常州网站建设哪家好网站上截小屏幕 怎么做
  • app 网站 优势网站常用插件
  • 创业网站推广怎么做新产品推广方案范文
  • 百度统计网站速度诊断象山经济开发区建设有限公司网站
  • 天塔网站建设公司如何在腾讯云上建设网站
  • 做外贸的人如何上国外网站wordpress评论通知作者
  • 网站常用模块功能说明做网站要注意的
  • 企业网站建设需求调查下载应用商店app
  • c 网站开发环境建立自信
  • 免费个人微网站运维工程师可以自学吗
  • 提供南昌网站建设公司网络优化app
  • 怎样建个自己的网站鄂州第一官方网站
  • 网站建设佰首选金手指十八网站怎么做视频背景
  • iis发布域名网站查询企业联系方式的软件
  • 接网站建设单子的网站创建网站的工作流程八年级信息技术