IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue3 — setup、reactive与ref细节 -> 正文阅读

[JavaScript知识库]Vue3 — setup、reactive与ref细节

setup细节

  • setup执行的时机

    • 在beforeCreate之前执行(一次), 此时组件对象还没有创建

    • this是undefined, 不能通过this来访问data/computed/methods / props

    • 其实所有的composition API相关回调函数中也都不可以

      <template>
        <h1>父组件-----</h1>
        <h3>{{ msg }}</h3>
        <button @click="msg += '+'">更新数据</button>
        <hr />
        <Child :msg="msg"/>
      </template>
      
      <script lang="ts">
      import { defineComponent, ref } from "vue";
      import Child from "./components/child.vue";
      
      export default defineComponent({
        name: "App",
        components: {
          Child,
        },
        setup() {
          const msg = ref("abcdef");
          return {
            msg
          }
        },
      });
      </script>
      
      
      <template>
        <h1>子组件</h1>
        <h3>{{msg}}</h3>
      </template>
      
      <script lang="ts">
      import { defineComponent } from "vue";
      
      export default defineComponent({
        name: "Child",
        props: ["msg"],
      
        beforeCreate() {
            console.log("beforeCreate");
            console.log(this.msg);
            
        },
        setup() {
            console.log("setup");
            console.log(this);
        }
      });
      </script>
      

      在这里插入图片描述

  • setup的返回值

    • 一般都返回一个对象: 为模板提供数据, 也就是模板中可以直接使用此对象中的所有属性/方法
    • 返回对象中的属性会与data函数返回对象的属性合并成为组件对象的属性
    • 返回对象中的方法会与methods中的方法合并成为组件对象的方法
    • 如果有重名, setup优先
    • 注意:
      • 一般不要混合使用: methods中可以访问setup提供的属性和方法, 但在setup方法中不能访问data和methods
      • setup不能是一个async函数: 因为async函数返回值是promise,而不是return,模板看不到return对象中的属性数据
      <template>
        <h1>{{a1}} -- {{a2}}</h1>
      </template>
      
      <script lang="ts">
      import { defineComponent, ref } from "vue";
      
      export default defineComponent({
        name: "Child",
        setup() {
            let a1 = ref("a1")
            let fn1 = () => {
                console.log("setup中的方法");
            }
            return {
                a1,
                fn1
            }
        },
        mounted() {
            // 检验有没有两个方法
            console.log(this);
        },
        data() {
            return {
                a2: "a2"
            }
        },
        methods: {
            fn2() {
                console.log("methods中的方法");      
            }
        }
      
      });
      </script>
      
      在这里插入图片描述
  • setup的参数

    • setup(props, context) / setup(props, {attrs, slots, emit})

    • props: 包含props配置声明且传入了的所有属性的对象

    • attrs: 包含没有在props配置中声明的属性的对象, 相当于 this.$attrs

    • slots: 包含所有传入的插槽内容的对象, 相当于 this.$slots

    • emit: 用来分发自定义事件的函数, 相当于 this.$emit

      <template>
        <h1>父组件-----</h1>
        <h3>{{ msg }}</h3>
        <button @click="msg += '+'">更新数据</button>
        <hr />
        <Child :msg="msg" xxx="xxx" @fn="fn"/>
      </template>
      
      <script lang="ts">
      import { defineComponent, ref } from "vue";
      import Child from "./components/child.vue";
      
      export default defineComponent({
        name: "App",
        components: {
          Child,
        },
        setup() {
          const msg = ref("abcdef");
          function fn(str: string) {
            msg.value += str
          }
          return {
            msg,
            fn
          }
        },
      });
      </script>
      
      <template>
        <h1>子组件</h1>
        <h3>{{msg}}</h3>
        <button @click="emitFn()">分发事件</button>
      </template>
      
      <script lang="ts">
      import { defineComponent } from "vue";
      
      export default defineComponent({
        name: "Child",
        props: ["msg"],
        
        setup(props, context) {
            // context可以直接解构为{ attrs, slots, emit }
            // props是一个对象,里面包含父组件向子组件传递的数据,props接收的所有数据
            console.log(props, context);
            // context -> emit
            function emitFn() {
                context.emit("fn", "子组件传来的")
            }
            return {
                emitFn
            }
        }
      
      });
      </script>
      

      在这里插入图片描述


reactive与ref细节

  • 是Vue3的 composition API中2个最重要的响应式API

  • ref用来处理基本类型数据, reactive用来处理对象(递归深度响应式)

  • 如果用ref对象/数组, 内部会自动将对象/数组转换为reactive的代理对象

  • ref内部: 通过给value属性添加getter/setter来实现对数据的劫持

  • reactive内部: 通过使用Proxy来实现对对象内部所有数据的劫持, 并通过Reflect操作对象内部数据

  • ref的数据操作: 在js中要.value, 在模板中不需要(内部解析模板时会自动添加.value)

    <template>
      <h3>m1: {{m1}}</h3>
      <h3>m2: {{m2}}</h3>
      <h3>m3: {{m3}}</h3>
      <hr>
      <button @click="updata">更新数据</button>
    </template>
    
    <script lang="ts">
    import { defineComponent, reactive, ref } from "vue";
    
    export default defineComponent({
      name: "App",
      
      setup() {
        
        // 通过ref的方式设置数据
        let m1 = ref("abc")
    
        let m2 = reactive({
          a: 'a',
          b: {
            c: 'c'
          }
        })
        // ref 传入对象?
        let m3 = ref({
          a: 'a',
          b: {
            c: 'c'
          }
        })
    
        let updata = function() {
          console.log(m1, m2, m3);
          m1.value += "111"
          m2.b.c += "222"
          m3.value.b.c += "333"
        }
        return {
          m1,
          m2,
          m3,
          updata
        }
      },
    });
    </script>
    

    在这里插入图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-19 11:53:09  更:2022-05-19 11:54:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:08:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码