小言_互联网的博客

vue3 +ts 第二篇

392人阅读  评论(0)

1.watch watchEffect 监听汇总

watch watchEffect
默认情况是惰性的,也就是说仅在侦听的源数据变更时才执行回调。 不需要手动传入依赖
更明确哪些状态的改变会触发侦听器重新运行副作用; 会先执行一次用来自动收集依赖
获取到侦听状态变化前后的值。 无法获取到变化前的值, 只能获取变化后的值

watch

监视单个


  
  1. let num = ref<number>( 10)
  2. watch(num, (nv,ov)=>{
  3. console. log(nv,ov);
  4. })

监视多个普通  返回的也是数组形式


  
  1. let num = ref<number>( 10)
  2. let str = ref<string>( '你好')
  3. watch([num,str], (nv,ov)=>{
  4. console. log(nv,ov);
  5. })

检测ref 对象    ref传入多级结构对象要加 deep 属性


  
  1. let refObj = ref<object>({
  2. r1:{
  3. r2: 'r1'
  4. }
  5. })
  6. watch (refObj, (nv,ov)=>{
  7. console. log(nv,ov, 'refObj');
  8. },{
  9. deep: true
  10. })

检测 reactive 对象  vue默认加了 deep 属性


  
  1. type propObj = {
  2. name:string;
  3. hobby: Object;
  4. home: {
  5. pri: string;
  6. };
  7. aa: Object
  8. };
  9. let ins = reactive<propObj[]>([
  10. {
  11. name: "ww",
  12. hobby: [ "play", "sing"],
  13. home: {
  14. pri: "henna",
  15. },
  16. aa: {
  17. bb: {
  18. cc: "ccc",
  19. },
  20. },
  21. },
  22. ]);
  23. watch(ins[ 0], (nv,ov)=>{
  24. console. log(nv,ov);
  25. })

ref 和 reactive  检测对象是 都检测不到 旧值  nv ov 都是最新的值

检测目标是多级对象某个属性    第一个参数写成回调的形式  这种形式能检测到旧的值


  
  1. let ins = reactive<propObj[]>([
  2. {
  3. name: "ww",
  4. hobby: [ "play", "sing"],
  5. home: {
  6. pri: "henna",
  7. },
  8. aa: {
  9. bb: {
  10. cc: "ccc",
  11. },
  12. },
  13. },
  14. ]);
  15. watch( ()=>ins[ 0]. aa. bb. cc, (nv,ov)=>{
  16. console. log(nv,ov); // c变了 ccc
  17. })
  18. let change =( )=>{
  19. ins[ 0]. aa. bb. cc = 'c变了'
  20. }

watchEffect

 


  
  1. let str = ref<string>( 'watchEffect1');
  2. let watchStop= watchEffect( (watchEcb)=>{
  3. console. log(str);
  4. watchEcb( ()=>{
  5. console. log( 'watchEcb');
  6. })
  7. })
  8. let ws = ( )=>{
  9. watchStop()
  10. }

watchEffect接收一个副作用函数 《watchEcb》

此外,watchEffect 接受一个函数作为参数 在函数体内用到的数据发生改变时会重新 触发该函数执行,而且 该函数还接受一个回调作为参数 《watchEcb》  watchEcb内的函数执行的时机 要比

watchEffect 调用的函数 执行的要快 ,可以再这里面 做防抖等 ,watchEffect 返回一个 回调

当停止监视时,执行该回调 会再触发一次 《watchEcb》  以后就不在监视

watch 和watchEffect 的 配置对象 option 内的属性

deep true  | fasle    <boolean>
immediate true  | false     <boolean>
fluse pre  | sync | post   <string>
pre 在组件更新更新前运行,默认为'pre'
sync 强制效果始终同步触发。然而,这是低效的,应该很少需要。
post 在组件更新更新后运行


转载:https://blog.csdn.net/gu2022_3_5_21_23/article/details/128430508
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场