isRef

检查某个值是否是ref。是返回true,否则返回false

const num = ref(10);
const num1 = 20;
const num2 = reactive({ data: 30 }); console.log(isRef(num)); //true
console.log(isRef(num1)); //false
console.log(isRef(num2)); //false

unref()

如果参数是ref,则返回内部值,否则返回参数本身。

这是  val = isRef(val) ? val.value : val  计算的一个语法糖。

console.log(unref(num));
console.log(unref(num1));
console.log(unref(num2));

toRef

介绍

基于响应式对象上的某个属性,创建一个对应的 ref。创建出来的 ref 会跟源属性保持同步:更改了 ref 的值就会更改源属性的值,反之亦然。

  • 参数一:操作对象
  • 参数二:对象属性
const val = reactive({
num: 1,
}); const numRef = toRef(val, "num"); // 更改该 ref 会更新源属性
numRef.value++;
console.log(val.num); // 2 // 更改源属性也会更新该 ref
val.num++;
console.log(numRef.value); // 3

使用场景

toRef()  这个函数在你想把一个 prop 的 ref 传递给一个组合式函数时会很有用当我们向组件传递 props 数据时,如果想要某个数据同父组件同步更新。当  toRef  与组件 props 结合使用时,关于禁止对 props 做出更改的限制依然有效。尝试将新的值传递给 ref 等效于尝试直接更改 props,这是不允许的。在这种场景下,可以使用watch去监听我们定义ref()对象。

<template>
<n-modal :show="props.visible">
<n-card
style="width: 600px"
title="编辑"
:bordered="false"
size="huge"
role="dialog"
aria-modal="true"
>
<n-input v-model:value="inputValue"></n-input>
<template #footer>
<n-el class="flex justify-end">
<n-space>
<n-button @click="emits('cancel')">取消</n-button>
<n-button @click="emits('save', inputValue)">确定</n-button>
</n-space>
</n-el>
</template>
</n-card>
</n-modal>
</template> <script lang="ts" setup>
import { toRef, watch, ref } from 'vue'
const props = defineProps<{
visible: boolean
value: string
}>() const emits = defineEmits<{
(e: 'save', data: string): void
(e: 'cancel'): void
}>() const valueToRef = toRef(props, 'value')
const inputValue = ref(props.value) watch(
() => valueToRef.value,
(v) => (inputValue.value = v)
)
</script>
<style></style>
  const visible = ref(true)
const inputValue = ref('哈哈哈哈')
const handleSave = (v: string) => {
console.log('v', v)
}
const handleCancel = () => {
visible.value = false
} <Demo :value="inputValue" :visible="visible" @save="handleSave" @cancel="handleCancel" />

注:视图更新的问题

参考: https://www.cnblogs.com/web-learn/p/16725393.html

toRefs()

将一个响应式对象转换为一个普通对象,这个普通对象的每个属性都指向源对象相应的属性的ref。每个单独的ref都是使用toRef()创建的。

const val = reactive({
num: 1,
}); const numRef = toRefs(val); // 更改该 ref 会更新源属性
numRef.num.value++;
console.log(val.num); // 2 // 更改源属性也会更新该 ref
val.num++;
console.log(numRef.num.value); // 3

toRefs()解构出来的对象不会失去响应性。

如下:

const obj = reactive({
num: 10,
num2: 20,
}); const { num1, num2 } = toRefs(obj);

toRefs  在调用时只会为源对象上可以枚举的属性创建 ref。如果要为可能还不存在的属性创建 ref,请改用  toRef

最新文章

  1. mac机上搭建php56/nginx 1.8.x/thinkphp 3.2.x/gearman扩展/seaslog扩展/redis扩展环境
  2. &lt;转&gt;MFC注册系统/全局热键。
  3. 【自动化测试】Xpath学习
  4. PHP MYSQL 数据库配置连接
  5. 【pm2】
  6. shell命令:echo命令详解
  7. linux添加、修改环境变量
  8. 45、concurrent.futures模块与协程
  9. Android 开发笔记___alertDialog
  10. 【打CF,学算法——三星级】Codeforces Round #313 (Div. 2) C. Gerald&amp;#39;s Hexagon
  11. 谢大神给的C++和C# DES加解密代码
  12. 安装二维码、条形码识别工具zbar
  13. C#做一个写txt文件流的测试,为什么配置低的机器写入的还快
  14. 七,apache配置域名
  15. ElasticSearch学习笔记(三)logstash安装和logstash-input-jdbc插件
  16. Linux命令应用大词典-第43章iptables和arptables防火墙
  17. Jtag To Axi4 debug 读写寄存器的tcl脚本封装
  18. GridView.setChoiceMode(GridView.CHOICE_MODE_MULTIPLE_MODAL)不兼容低版本号系统解决方式
  19. MySQL计算指标连续两月金额相比_20160929
  20. R语言集合函数

热门文章

  1. React 函数组件
  2. Optional用法与争议点
  3. 自动增加 Android App 的版本号
  4. 【Devexpres】spreadsheetControl设置可见范围
  5. 【devexpress】spinEdit控件如何设置只能输入两位小数
  6. mybatis中xml的sql之test中文报错
  7. 如何解决arthas-failed-to-bind-telnet-or-http-port问题
  8. 大数据HDFS凭啥能存下百亿数据?
  9. 解析【.mdb】文件
  10. Linux系统CentOS6找回密码解决方法