首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
10.1 注册自定义指令
10.1.1 全局自定义指令
10.1.2 局部自定义指令
10.2 钩子函数
10.3 绑定值的类型
10.3.1 绑定数值
10.3.2 绑定字符串
10.3.3 绑定对象字面量
11.1 注册组件
11.1.1 注册全局组件
11.1.2 注册局部组件
11.2 向子组件传递数据
11.2.1 Prop基本用法
11.2.2 数据验证
11.3 监听子组件事件
11.3.1 监听自定义事件
11.3.2 监听原生事件
11.4 插槽的使用
11.4.1 基础用法
11.4.2 编译作用域
11.4.3 默认内容
11.4.4 命名插槽
11.4.5 作用域插槽
11.5 混入
11.5.1 基础用法
11.5.2 选项合并
11.6 动态组件
11.6.1 动态组件的用法
11.6.2 缓存效果
12.1 什么是组合API
12.2 setup()函数
12.3 响应式API
12.3.1 reactive()方法
12.3.2 watchEffect()方法
12.3.3 ref()方法
12.3.4 computed()方法
12.3.5 watch()方法
12.4 生命周期钩子函数
12.5 使用ref获取DOM元素
13.1 单元素过渡
13.1.1 CSS过渡
13.1.2 过渡的类名
13.1.3 自定义过渡的类名
13.1.4 CSS动画
13.1.5 使用JavaScript钩子函数实现动画
13.2 多元素过渡
13.2.1 多元素过渡的用法
13.2.2 设置元素的key属性
13.2.3 过渡模式的设置
13.3 多组件过渡
13.4 列表过渡
14.1 什么是虚拟DOM
14.2 render()函数的使用
14.2.1 基本用法
14.2.2 h()函数
14.3 使用JavaScript代替模板功能
15.1 路由基础
15.1.1 引入Vue Router
15.1.2 基本用法
15.1.3 动态路由匹配
15.1.4 命名路由
15.2 编程式导航
15.3 嵌套路由
15.4 命名视图
15.5 高级用法
15.5.1 beforeEach钩子函数
15.5.2 scrollBehavior方法
当前位置:
首页>>
技术小册>>
Vue.js从入门到精通(三)
小册名称:Vue.js从入门到精通(三)
### 12.3.3 ref() 方法:Vue 3 Composition API 的核心构件 在 Vue 3 中,Composition API 的引入为开发者提供了一种全新的方式来组织和重用逻辑。作为 Composition API 的核心工具之一,`ref()` 方法扮演着至关重要的角色。它不仅简化了响应式数据的创建过程,还促进了组件逻辑的清晰分离和复用。本章将深入解析 `ref()` 方法的原理、用法、最佳实践以及在复杂场景中的应用。 #### 12.3.3.1 理解 `ref()` 方法的基础 `ref()` 是 Vue 3 中用于创建一个响应式引用的函数。与 Vue 2 的响应式系统不同,Vue 3 引入了 Proxy 来实现更深层次的响应式,而 `ref()` 正是这一新系统下的产物。当你调用 `ref()` 并传入一个初始值时,它会返回一个响应式且可变的 ref 对象。这个对象拥有一个 `.value` 属性,用于访问或修改其内部的值。 **基本用法示例**: ```javascript import { ref } from 'vue'; const count = ref(0); console.log(count.value); // 输出: 0 count.value++; console.log(count.value); // 输出: 1 ``` 在这个例子中,`count` 是一个响应式的引用,其内部值通过 `.value` 属性进行访问和修改。每当 `.value` 的值发生变化时,任何依赖于这个 ref 的视图或计算属性都会自动更新。 #### 12.3.3.2 `ref()` 与原始值的差异 使用 `ref()` 创建的响应式引用与直接使用原始值(如数字、字符串等)在行为上存在显著差异。原始值在 JavaScript 中是按值传递的,而 `ref()` 返回的引用是按引用传递的。这意味着当你将 `ref()` 的返回值传递给函数或组件时,你实际上传递的是对内部值的引用,而不是值本身。 **对比示例**: ```javascript // 使用原始值 let primitiveCount = 0; function incrementPrimitive() { primitiveCount++; } // 使用 ref() const refCount = ref(0); function incrementRef() { refCount.value++; } incrementPrimitive(); // 原始值变化 console.log(primitiveCount); // 输出: 1 incrementRef(); // ref 值变化 console.log(refCount.value); // 输出: 1 ``` 在组件间传递数据时,`ref()` 的这种特性尤为重要,因为它允许父组件通过 props 将响应式引用传递给子组件,子组件则可以通过修改 `.value` 来更新数据,从而触发视图的更新。 #### 12.3.3.3 在模板中使用 `ref()` 虽然 `ref()` 主要是为了在 JavaScript 逻辑中使用,但 Vue 3 提供了 `.value` 的自动解包功能,使得在模板中可以直接访问 `ref` 的值而无需 `.value`。 **模板示例**: ```vue <template> <div> <p>{{ count }}</p> <button @click="increment">Increment</button> </div> </template> <script> import { ref } from 'vue'; export default { setup() { const count = ref(0); function increment() { count.value++; } return { count, increment }; } } </script> ``` 在这个例子中,尽管 `count` 是一个 `ref` 对象,但在模板中可以直接使用 `{{ count }}` 来访问其 `.value` 属性,无需显式编写 `.value`。 #### 12.3.3.4 `ref()` 在 Composition API 中的高级用法 `ref()` 的强大之处不仅限于基本的数据绑定,它还可以与其他 Composition API 函数(如 `reactive`、`computed`、`watch` 等)结合使用,以实现更复杂的功能。 **与 `watch` 结合使用**: ```javascript import { ref, watch } from 'vue'; const counter = ref(0); watch(counter, (newValue, oldValue) => { console.log(`Counter changed from ${oldValue} to ${newValue}`); }); // 稍后,当 counter.value 改变时,watch 回调将被触发 ``` **与 `computed` 结合使用**: ```javascript import { ref, computed } from 'vue'; const base = ref(10); const double = computed(() => base.value * 2); // 当 base.value 改变时,double 会自动更新 ``` #### 12.3.3.5 最佳实践 - **避免在模板中直接修改 `ref` 的值**:虽然技术上可行,但直接在模板中修改 `ref` 的值(如通过事件处理函数)可能会导致代码难以理解和维护。建议将所有逻辑封装在 `setup()` 函数内。 - **合理使用 `.value`**:在 JavaScript 逻辑中始终通过 `.value` 访问或修改 `ref` 的值。在模板中,Vue 会自动处理解包。 - **结合其他 Composition API 使用**:`ref()` 与其他 Composition API 函数(如 `reactive`、`computed`、`watch` 等)的配合使用,可以构建出既灵活又强大的响应式系统。 - **考虑使用 `shallowRef`**:对于大型对象或数组,如果你只需要响应式地追踪其引用变化而非内部属性的变化,可以使用 `shallowRef` 来优化性能。 #### 12.3.3.6 总结 `ref()` 方法作为 Vue 3 Composition API 的基石之一,极大地丰富了 Vue 应用的开发方式和可能性。通过掌握 `ref()` 的基本用法、理解其与原始值的差异、学习在模板中的使用方式、探索与其他 Composition API 的结合使用以及遵循最佳实践,你将能够更加高效、灵活地构建 Vue 应用。随着 Vue 3 生态的不断发展,`ref()` 及其背后的响应式原理将继续为开发者们带来惊喜和便利。
上一篇:
12.3.2 watchEffect()方法
下一篇:
12.3.4 computed()方法
该分类下的相关小册推荐:
Vue原理与源码解析
Vue.js从入门到精通(四)
TypeScript和Vue从入门到精通(五)
vue项目构建基础入门与实战
vuejs组件实例与底层原理精讲
Vue源码完全解析
TypeScript和Vue从入门到精通(二)
移动端开发指南
TypeScript和Vue从入门到精通(四)
TypeScript和Vue从入门到精通(三)
Vue.js从入门到精通(一)
Vue.js从入门到精通(二)