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

wordpress音乐播放器插件百度seo排名优化

wordpress音乐播放器插件,百度seo排名优化,怎么在凡科做自己网站,wordpress建设资源站点插件watch 的第一个参数可以是不同形式的“数据源”&#xff1a;它可以是一个 ref (包括计算属性)、一个响应式对象、一个 getter 函数、或多个数据源组成的数组&#xff1a; 1&#xff1a;reactive监听对象 <template><div><h1>情况二&#xff1a;watchEffect…

watch 的第一个参数可以是不同形式的“数据源”:它可以是一个 ref (包括计算属性)、一个响应式对象、一个 getter 函数、或多个数据源组成的数组:

1:reactive监听对象

<template><div><h1>情况二:watchEffect自动监视数据</h1><h2>两个数字的和:{{ count }}</h2></div>
</template>
<script setup lang="ts" name="DemoWatch">
import { reactive, ref, watch } from 'vue'let count = ref(0)const sum = reactive({a: 1,b: 2
})watch(
//source() => {console.log('x')return sum.a + sum.b},
//cb(value) => {console.log('执行回调sum:', value)})setTimeout(() => {sum.a++sum.b--console.log('执行定时器了')
}, 1000)</script>
<style scoped></style>

执行结果如下

在这里插入图片描述

分析:组件一开始挂载先执行一次监听中的source,一秒后,因为对sum.a或sum.b操作,所以又执行了一次source,但是source的返回值都没有发生变化,所以都没有执行回调函数(cb),这样监听只有当sum.a + sum.b返回的值发生变化,才会执行回调函数(cb)

2:reactive监听对象(使用 immediate: true,立即执行一次回调函数(cb))

<template><div><h1>情况二:watchEffect自动监视数据</h1><h2>两个数字的和:{{ count }}</h2></div>
</template>
<script setup lang="ts" name="DemoWatch">
import { reactive, ref, watch } from 'vue'let count = ref(0)const sum = reactive({a: 1,b: 2
})watch(//source() => {console.log('x')return sum.a + sum.b},//cb(value) => {console.log('执行回调sum:', value)},//  立即执行一次回调函数(cb){immediate: true}
)setTimeout(() => {sum.a++sum.b--console.log('执行定时器了')
}, 1000)
</script>
<style scoped></style>

执行结果如下

在这里插入图片描述

3:reactive监听对象(使用 immediate: true,立即执行一次回调函数(cb))

<template><div><h1>情况二:watchEffect自动监视数据</h1><h2>两个数字的和:{{ count }}</h2></div>
</template>
<script setup lang="ts" name="DemoWatch">
import { reactive, ref, watch } from 'vue'let count = ref(0)const sum = reactive({a: 1,b: 2
})watch(//source() => {console.log('x')return sum.a + sum.b},//cb(value) => {console.log('执行回调sum:', value)},// 深度监听{deep: true}
)setTimeout(() => {sum.a++sum.b--console.log('执行定时器了')
}, 1000)
</script>
<style scoped></style>

执行结果如下

在这里插入图片描述

分析:为什么加了深度监听后会执行回调?如果你添加了 { deep: true } 选项,即使计算值相同,回调也会执行,这是因为:

1:深度监听的机制:deep: true 会让 Vue 不仅比较计算结果的最终值,还会追踪依赖项的变化

2:依赖项变化:虽然 sum.a + sum.b 的结果没变,但 sum.a 和 sum.b 本身都发生了变化

3:触发条件:深度监听下,只要依赖的响应式数据 (这里是 sum.a 和 sum.b) 发生了变化,就会触发回调,不管计算结果是否相同

如果你希望在依赖项变化时总是执行回调,即使计算结果相同,可以使用 watchEffect:

watchEffect(() => {const value = sum.a + sum.bconsole.log('执行回调sum:', value)
})

或者如果你想保持使用 watch 但总是触发,可以添加 flush: ‘sync’ 选项:

watch(() => sum.a + sum.b,(value) => {console.log('执行回调sum:', value)},{ deep: true, flush: 'sync' }
)

总结:
默认情况下 watch 只在返回值变化时触发
deep: true 会让它追踪依赖项的变化,即使返回值相同也会触发

4:reactive监听对象

<template><div><h1>情况二:watchEffect自动监视数据</h1><h2>两个数字的和:{{ count }}</h2></div>
</template>
<script setup lang="ts" name="DemoWatch">
import { reactive, ref, watch } from 'vue'let count = ref(0)const sum = reactive({a: 1,b: 2,c: 3
})watch(//source() => {console.log('x:', sum.c)return sum.a + sum.b},//cb(value) => {console.log('执行回调sum:', value)}
)setTimeout(() => {sum.c++console.log('执行定时器了')
}, 1000)
</script>
<style scoped></style>

执行结果如下

在这里插入图片描述

分析:一开始先执行source方法所以打印了x:3,又因为一秒后修改了c的值,同时source中对c有监听,所以又执行了一次source,但是因为返回的都是a+b,返回值没有变化,所以不执行回调函数(cb)

5:reactive监听对象

watch(//source() => {console.log('x:', sum.c = 10)  //修改了 `sum.c`,但没有 **读取** 它(不是依赖)return sum.a    // 只有 `sum.a` 被 **读取**,所以 Vue 只监听 `sum.a` 的变化},//cb(value) => {console.log('执行回调sum:', value)}
)setTimeout(() => {sum.c++console.log('执行定时器了')
}, 1000)

执行结果如下

在这里插入图片描述

5-1:reactive监听对象

watch(//source() => {console.log('x:', sum.c === 10)  //读取 `sum.c`, **读取** 它(是依赖)return sum.a  // 只有 `sum.a` 被 **读取**,所以 Vue 只监听 `sum.a` 的变化},//cb(value) => {console.log('执行回调sum:', value)}
)setTimeout(() => {sum.c++console.log('执行定时器了')
}, 1000

执行结果如下

在这里插入图片描述

总结:如果 getter 函数内部有代码修改了响应式数据(如 sum.c = 10),但 没有读取它,则 Vue 不会 将其视为依赖,因此不会触发重新执行,(sum.c === 10),读取它,则 Vue 会 将其视为依赖,会触发重新执行

6:在 Vue 3 的 watch API 中,reactive的对象,使用函数返回值 () => sum 和直接使用 sum 作为侦听源(source)有重要区别

6-1:reactive的对象执行结果

<template><div><h1>情况二:watchEffect自动监视数据</h1><h2>两个数字的和:{{ count }}</h2></div>
</template>
<script setup lang="ts" name="DemoWatch">
import { reactive, ref, watch } from 'vue'let count = ref(0)const sum = reactive({person: { age: 18, name: '张三' },b: 2,c: 3
})watch(// source() => {console.log('x')return sum},// sum,//cb(value) => {console.log('执行回调sum:', value)}
)setTimeout(() => {sum.person.name = '李四'console.log('执行定时器了')
}, 1000)
</script>
<style scoped></style>

执行结果如下

在这里插入图片描述

6-2:reactive的对象执行结果

<template><div><h1>情况二:watchEffect自动监视数据</h1><h2>两个数字的和:{{ count }}</h2></div>
</template>
<script setup lang="ts" name="DemoWatch">
import { reactive, ref, watch } from 'vue'let count = ref(0)const sum = reactive({person: { age: 18, name: '张三' },b: 2,c: 3
})watch(// source// () => {//   console.log('x')//   return sum// },sum,//cb(value) => {console.log('执行回调sum:', value)}
)setTimeout(() => {sum.person.name = '李四'console.log('执行定时器了')
}, 1000)
</script>
<style scoped></style>

执行结果如下

在这里插入图片描述

总结区别:

方式监听目标深度监听适合场景
watch(sum, cb)整个响应式对象自动开启需要深度监听所有变化
watch(() => sum, cb)对象的引用不开启几乎无用(reactive 引用不变)
watch(() => sum.xxx, cb)特定属性不开启精确监听特定属性

7:在 Vue 3 的 watch API 中,ref的对象,使用函数返回值 () => sum 和直接使用 sum 作为侦听源(source)有重要区别

7-1:ref的对象执行结果

<template><div><h1>情况二:watchEffect自动监视数据</h1><h2>两个数字的和:{{ count }}</h2></div>
</template>
<script setup lang="ts" name="DemoWatch">
import { reactive, ref, watch } from 'vue'let count = ref(0)const sum = ref({person: { age: 18, name: '张三' },b: 2,c: 3
})watch(// source// () => {//   console.log('x')//   return sum.value// },sum,//cb(value) => {console.log('执行回调sum:', value)}
)setTimeout(() => {sum.value.person.name = '李四'console.log('执行定时器了')
}, 1000)
</script>
<style scoped></style>

执行结果如下

在这里插入图片描述

7-2:ref的对象执行结果

<template><div><h1>情况二:watchEffect自动监视数据</h1><h2>两个数字的和:{{ count }}</h2></div>
</template>
<script setup lang="ts" name="DemoWatch">
import { reactive, ref, watch } from 'vue'let count = ref(0)const sum = ref({person: { age: 18, name: '张三' },b: 2,c: 3
})watch(// source() => {console.log('x')return sum.value},// sum,//cb(value) => {console.log('执行回调sum:', value)}
)setTimeout(() => {sum.value.person.name = '李四'console.log('执行定时器了')
}, 1000)
</script>
<style scoped></style>

执行结果如下

在这里插入图片描述

总结区别:

监听方式触发条件深度监听适用场景
watch(sum, cb)仅 sum.value = newObj 时触发监听整个 ref 替换
watch(sum.value, cb)同理成reactive深度监听嵌套变化(不推荐)不推荐(可能丢失响应性)
watch(() => sum.value, cb, { deep: true })度监听嵌套变化推荐(清晰且可控)
watch(() => sum.value.xxx, cb)监听特定属性精确监听,性能优化

注意:如果使用ref包裹的对象,使用ref.value得到后是一个代理,就同理成reactive

在这里插入图片描述

http://www.dtcms.com/wzjs/129886.html

相关文章:

  • 网站上微信的链接怎么做深圳网络优化公司
  • 做公司网站要注意什么网站建设方案范文
  • 手机版网站开发实例发布信息的免费平台
  • 自己做下载网站桂平网络推广
  • 可做外链的网站今日国内新闻大事
  • 合肥庐阳区建设局网站企业网站建设的作用
  • 设计建设网站公司哪家好网站关键词免费优化
  • 网站建设推广技术百度指数怎样使用
  • 公众号做漫画网站千锋教育的口碑怎么样
  • 网站开发网络结构图南宁百度seo排名公司
  • wordpress需要钱吗百度百科优化
  • html5移动网站开发重庆seo霸屏
  • 卖产品怎么做网站武汉疫情最新动态
  • 网站内容与功能模块设计越秀seo搜索引擎优化
  • 网站ip如何做跳转开网店怎么推广运营
  • zion小程序开发网站移动端优化工具
  • 公众号开发服务招标公告长春seo主管
  • 国内适合个人做外贸的网站有哪些教育培训机构排名前十
  • 新网站建设方案申请网站域名要多少钱
  • 中徽园林建设有限公司网站深圳媒体网络推广有哪些
  • 织梦做的网站打开慢百度竞价排名推广
  • 杭州开发网站数据分析平台
  • 宁波网站推广软件哪家强些宁波seo网络推广报价
  • 2015做外贸网站好做吗杭州seo公司服务
  • 主流网站网络营销方式有哪些分类
  • 天津西青区旅游景点大全重庆网站seo教程
  • 如何做网站的内链优化武汉大学人民医院怎么样
  • 电商网站商品表设计哪里可以学seo课程
  • 上海做公司网站多少钱seo刷关键词排名工具
  • 网站开发 作品理念太原网络推广价格