vue3 中的 ref(params) 理解【个人观点,可供参考】

8 篇文章 0 订阅
7 篇文章 0 订阅
本文解析Vue3的ref函数如何创建响应式变量,讲解了ref底层原理与使用场景,涉及传递普通值、null、对象和泛型值的情况,并揭示了ref与Proxy的关系。通过实例演示了ref的动态监听和Proxy在值变化检测中的作用。
摘要由CSDN通过智能技术生成

刚接触 vue3.x ,在很多地方见到 ref(), 通过查阅资料更多的理解它是做什么用的

场景
// 1、传递一个普通值
const testRef = ref(1)
console.log(testRef, '======testRef=====');

// 2、传递一个 `null`
const testRef = ref(null)
console.log(testRef, '======testRef=====');

// 3、传递一个对象
const testRef = ref(obj)
console.log(testRef, '======testRef=====');

// 4、传递一个指定泛型的普通值
const testRef = ref<T>('')
console.log(testRef, '======testRef=====');

[疑问]:这些都代表的啥意思呢??

查阅资料
官网

ref

接受一个内部值并返回一个响应式且可变的 ref 对象。ref 对象仅有一个 .value property,指向该内部值。

看完后明白了其用于操作一个响应式对象,且该对象只包含一个value属性,但还是一头雾水

博客

1、vue3中ref的理解 - 山竹回家了

  • 1.什么是ref?
    • ref和reactive一样,也是用来实现响应式数据的方法
    • 由于reactive必须传递一个对象,所以在实际开发中如果只是想让某个变量实现响应式的时候回非常麻烦
    • 所以Vue3提供了ref方法实现简单值得监听
  • 2.ref本质
    • ref底层其实还是reactive,所以当运行时系统会自动根据传入的ref转换成reactive.
  • 3.ref注意点
    • 在vue中使用ref的值不用通过value获取
    • 在js中使用ref的值必须通过value获取

少许有点了解它的使用,知道了它底层还是基于reactive(什么是reactive,请参阅下一篇),主要是为了解决reactive不支持普通值实现响应式变化监听

2、vue3之ref()理解 - 昕昕念念

ref()实际就是把传入的值对象或引用对象统一转换成Proxy对象,用于监听对象的变动,因为Proxy只支持引用对象,所以对于值对象, 会转换成{ value: 值 } 再转换成Proxy对象,此时就可以监听到value值的变化

Proxy介绍可以参见官网:

Proxy - JavaScript | MDNdeveloper.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Proxy

目前Proxy的监听是单层的,new Proxy(obj) 只会把obj转成Proxy对象,obj内部的引用对象并不会转换,所以obj.a的变动可以监测到,而obj.a.b的变动就无法监测到了, 这个是刚使用Proxy时一个容易迷惑的点, 如果想要监听全部变动,只需要递归把对象内多有的引用对象全部转成Proxy对象就可以了

3、Vue3.x中的ref属性剖析(一看就懂) - BUG制造顶级工程师

总结

刚开始一直不明白 ref(params) 方法中 传递的参数 是什么意思,其实可以将其理解为传递的参数就是 当前声明的变量的初始值,同时是响应式的数据,又因ref 对象仅有一个 .value property,并指向其内部值,所以可以通过 .value来进行访问,vue 会在当前变量值改变时立刻更新数据并渲染

// 这个例子可以看看
const test = ref(1)
console.log(test, test.value, 'test1');
test.value++
console.log(test, test.value, 'test2');

:: 更多内容 ::

> 开发过程中踩坑经验记录

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3params是一种用于路由传参的方式。可以通过在路由配置使用params来定义参数,并在页面跳转时传递参数。使用params传参的方式可以在路由配置的path定义参数,然后在跳转时通过路由链接或者编程式导航的方式传递参数。 在模板可以通过使用{{ route.params.id }}来获取传递的参数。其route是通过使用useRoute函数获取到的路由对象。在模板直接使用route.params.id就可以获取到传递的参数值。 举个例子,如果在路由配置定义了一个名为users的路由,并且在path使用了params传参的方式,如下所示: ``` { path: '/user/:id', name: "users", component: User } ``` 在页面可以通过router-link或者编程式导航的方式跳转到这个路由,并传递参数。例如: ``` <router-link :to="{ name: 'users', params: { id: this.id}}"> 按钮 </router-link> ``` 或者 ``` this.$router.push({name:'users',params:{id: this.id}}) ``` 或者 ``` this.$router.push('/user/' + this.id) ``` 然后在用户组件的模板,可以使用{{ route.params.id }}来获取传递的参数值。 总结起来,Vue3params是一种用于路由传参的方式,可以在路由配置定义参数,并在页面跳转时传递参数,然后在接收页面通过route.params来获取传递的参数值。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [vue3路由传参query、params及动态路由传参详解](https://blog.csdn.net/WuLex/article/details/127914291)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值