Vue3.0实现todolist- ref定义单个数据和reactive定义对象类型的数据

简介: Vue3.0实现todolist- ref定义单个数据和reactive定义对象类型的数据

参考文档

参考文档:https://blog.csdn.net/ll666888999/article/details/123789098

参考视频:https://www.imooc.com/learn/1300

官方文档查看文档:https://v3.cn.vuejs.org/

1:ref定义单个数据

vue3.0中,用谁就要引用谁

import{ defineComponent,ref} from "vue";
  • ref定义数据
    引用ref,定义的数据在setup函数中定义,num初始值为10

setup() {
    let num = ref(10);
    let name = ref("jack");
    return {
      num,
      name,
    };
  },

{{}}差值表达式,把数据名插入两个大括号里

<div>{{ num }}</div>
    <div>{{ name }}</div>

这样就定义了一个num初始值为10,name初始值为Jack,运行结果:

====================================

  • ref也可以定义数组

若要得到数组的第一项

setup() {
    //定义数组
    let arr = ref(["a", "b", "c", "d"]);
    return {
      arr,
    };
  },
<div>{{ arr[1] }}</div>

打印结果

====================================

  • ref也可以定义对象

setup() {
    ///ref也可以定义对象
    let obj = ref({
      age: 20,
      name: "wang",
    });
    return {
      obj,
    };
  },
<div>{{ obj.age }}</div>
    <div>{{ obj.name }}</div>

打印结果

Home.vue

<template>
  <div>
    <nav-header></nav-header>
    <nav-main></nav-main>
    <nav-footer></nav-footer>
    <div>{{ num }}</div>
    <div>{{ name }}</div>
    <div>{{ arr[1] }}</div>
    <div>{{ obj.age }}</div>
    <div>{{ obj.name }}</div>
  </div>
</template>
<script>
import NavHeader from "@/components/navHeader/NavHeader.vue";
import NavMain from "@/components/navMain/NavMain.vue";
import NavFooter from "@/components/navFooter/NavFooter.vue";
//reactive定义对象类型的数据
import { defineComponent, ref, reactive } from "vue";
export default defineComponent({
  name: "Home",
  props: {},
  components: {
    NavHeader,
    NavMain,
    NavFooter,
  },
  setup(props, ctx) {
    let num = ref(10);
    let name = ref("jack");
    //定义数组
    let arr = ref(["a", "b", "c", "d"]);
    ///ref也可以定义对象
    let obj = ref({
      age: 20,
      name: "wang",
    });
    return {
      num,
      name,
      arr,
      obj,
    };
  },
});
</script>
<style>
</style>

2:reactive定义对象类型的数据

首先引用reactive

import { defineComponent, reactive } from "vue";

然后 定义对象类型的数据

setup() {
    //方法定义
    let data = reactive({
      name: "wang",
      age: 21,
      obj: {
        price: 20,
      },
      arr: ["a", "b", "c", "d"],
    });
    return {
      data,
    };
  },
<div>{{ data.age }}</div>
    <div>{{ data.name }}</div>
    <div>{{ data.arr }}</div>
    <div>{{ data.obj }}</div>

demo

<template>
  <div>
    <nav-header></nav-header>
    <nav-main></nav-main>
    <nav-footer></nav-footer>
    <div>{{ data.age }}</div>
    <div>{{ data.name }}</div>
    <div>{{ data.arr }}</div>
    <div>{{ data.obj }}</div>
  </div>
</template>
<script>
import NavHeader from "@/components/navHeader/NavHeader.vue";
import NavMain from "@/components/navMain/NavMain.vue";
import NavFooter from "@/components/navFooter/NavFooter.vue";
//reactive定义对象类型的数据
import { defineComponent, reactive } from "vue";
export default defineComponent({
  name: "Home",
  props: {},
  components: {
    NavHeader,
    NavMain,
    NavFooter,
  },
  setup() {
    //方法定义
    let data = reactive({
      name: "wang",
      age: 21,
      obj: {
        price: 20,
      },
      arr: ["a", "b", "c", "d"],
    });
    return {
      data,
    };
  },
});
</script>
<style>
</style>

如果不想写上面的data.

引用toRefs 可以把reactive定义的响应式对象转换成普通对象

import { defineComponent, reactive, toRefs } from "vue";
setup() {
    //方法定义
    let data = reactive({
      name: "wang",
      age: 21,
      obj: {
        price: 20,
      },
      arr: ["a", "b", "c", "d"],
    });
    return {
      //data,
      ...toRefs(data)
    };
  },
<div>{{ age }}</div>
    <div>{{ name }}</div>
    <div>{{ arr }}</div>
    <div>{{ obj }}</div>
相关文章
|
27天前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
128 64
|
1月前
|
监控 JavaScript 算法
深度剖析 Vue.js 响应式原理:从数据劫持到视图更新的全流程详解
本文深入解析Vue.js的响应式机制,从数据劫持到视图更新的全过程,详细讲解了其实现原理和运作流程。
|
1月前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
63 1
|
1月前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
64 1
|
1月前
|
前端开发 JavaScript
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
|
2月前
|
API
vue3知识点:reactive对比ref
vue3知识点:reactive对比ref
33 3
|
2月前
|
API
vue3知识点:响应式数据的判断
vue3知识点:响应式数据的判断
31 3
|
2月前
|
JavaScript API
vue3知识点:ref函数
vue3知识点:ref函数
41 2
|
2月前
|
API
vue3知识点:reactive函数
vue3知识点:reactive函数
37 1
|
2月前
|
存储 缓存 JavaScript
vue表单案例练习:vue表单创建一行数据及删除数据的实现与理解
vue表单案例练习:vue表单创建一行数据及删除数据的实现与理解
49 2