1、setup()

vue3中的composition API中最重要的就是setup方法了,相当于组件的入口,所有的composition API都必须放到setup()中的使用。

setup是在组件实例初始化之前执行的(beforeCreated之前),是整个组件的入口函数,这个时候数据和方法还没有进行挂载,因此在setup中this并不会执行当前组件实例,也不能通过this获取组件中的数据和方法了。

在模板中使用到的变量和方法必须在setup中return出来,才能使用。

export default {
setup(){
let name="张三"
return {name}//必须在这里return,模板中才能使用过
}
}

setup中的参数

上面已经说过,因为setup是在beforeCreate之前执行的,所以setup中的this并不会指向当前组件实例,this的值为undefined,那么我们怎么和父子组件通信呢(之前可以通过this.$emit触发)?这时就需要用到setup的参数了。

setup有两个参数,第一个是props,父组件传递给当前组件的prop都在这个参数对象中,第二个参数是上下文context,里面包含后attrs,emit,slots,这几个参数的用法就和vue2中的大同小异了,这里不做过多赘述。

2、ref用来定义基础类型的响应式数据

在setup中直接定义的变量不是响应式的,如果需要定义基础类型的响应式变量,需要使用ref来定义

import {ref} from "vue"
export default {
setup(){
let name = '张三';
setTimeout(() => {
name = '李四';
console.log(name);//这里的改变了,但是视图并不会更新
}, 2000);
return { name };
}
}
import {ref} from "vue"
export default {
let name = ref('张三');
setTimeout(() => {
name.value = '李四';
console.log(name.value); //李四
}, 2000);
return { name };
}

需要注意的是,通过ref定义的变量,在js中使用的时候需要通过.value来获取或者设置值,但是在模板中使用的时候不需要加.value,vue内部已经帮我们处理了。

通过ref获取dom元素或者组件实例

在vue2中要获取dom元素或者组件实例,直接在dom元素或者组件上添加ref="refName",然后在js中通过this.$refs.refName就可以获取了。在vue3中,使用方式略有不同。

  1. 直接在dom元素或者组件上添加ref="refName"
  2. 在setup中定义ref,初始值为null,let refName=ref(null),注意变量的名字一定要和dom或者组件上的ref名字保持一致。
  3. 在js中通过refName.value获取dom元素或者组件实例
  4. 注意,需要在setup总return使用到的ref变量
<template>
<div ref="name">张三</div>
<button @click="change">add</button>
<hr />
</template> <script>
import { ref } from 'vue';
export default {
setup() {
let name = ref(null);
const change = () => {
console.log(name.value);
name.value.innerText = '李四';
};
return { name, change };
},
};
</script>

3、reactive用来定义引用类型的响应式数据

import { reactive } from 'vue';
export default {
setup() {
let obj = reactive({ name: '张三', age: 18 });
setTimeout(() => {
obj.name = '李四';
console.log(obj); //李四
}, 2000);
return { obj };
},
};

在模板中直接通过{{obj.name}}就可以访问数据了

4、computed计算属性

创建只读的计算属性

import {ref,computed} from "vue"
export default {
setup(){
let count=ref(0)
let newCount=computed(()=>count.value+10)
return {count,newCount}
}
}

创建可读可写的计算属性,在computed中传入一个对象,通过设置get和set方法创建可读写的计算属性。

import { ref, computed } from 'vue';
export default {
setup() {
let count = ref(1);
let newCount = computed({
get: () => count.value + 100,
set: val => (count.value = val - 1),
});
let change = () => (newCount.value += 100);//给计算属性赋值会触发set
return { count, newCount, change };
},
}

5、watch监听

监听ref类型的单个数据

import { ref, computed, watch } from 'vue';
export default {
setup() {
let count = ref(1);
let newCount = computed({
get: () => count.value + 100,
set: val => (count.value = val - 1),
});
let change = () => (newCount.value += 100);
watch(count, (newVal, oldVal) => {
console.log(newVal, oldVal);
});
return { count, newCount, change };
},
};

监听ref类型的多个值

import { ref, watch } from 'vue';
export default {
setup() {
let name = ref('张三');
let age = ref(18); setTimeout(() => {
name.value = '李四';
age.value = 22;
}, 2000); watch([name, age], ([newName, newAge], [oldName, oldAge]) => {
console.log(newName, newAge); //李四 22
console.log(oldName, oldAge); //张三 18
});
return { name, age };
},
};

监听reactive类型的单个值

import { reactive, watch } from 'vue';
export default {
setup() {
let obj = reactive({ name: '张三', age: 18 });
setTimeout(() => {
obj.name = '李四';
}, 2000); watch(
() => obj.name,
(newVal, oldVal) => {
console.log(newVal, oldVal); //李四 张三
}
);
return { obj };
},
};

监听reactive类型的多个值

import { reactive, watch } from 'vue';
export default {
setup() {
let obj = reactive({ name: '张三', age: 18 });
setTimeout(() => {
obj.name = '李四';
obj.age = 22;
}, 2000); watch(
[() => obj.name, () => obj.age],
([newName, newAge], [oldName, oldAge]) => {
console.log(newName, newAge); //李四 22
console.log(oldName, oldAge); //张三 18
}
);
return { obj };
},
};

watch添加配置项

在vue2中watch如果需要添加配置就需要传入一个对象,来配置immediate和deep,在vue3中的watch同样可以在第三个参数里添加配置

import { ref, watch } from 'vue';
export default {
setup() {
let name = ref('张三');
let age = ref(18); setTimeout(() => {
name.value = '李四';
age.value = 22;
}, 2000); watch(
[name, age],
([newName, newAge], [oldName, oldAge]) => {
console.log(newName, newAge);
console.log(oldName, oldAge);
},
{
immediate: true,
deep: true,
}
);
return { name, age };
},
};

6、watchEffect监听

import { ref, watch, watchEffect } from 'vue';
export default {
setup() {
let name = ref('张三');
let age = ref(18); setTimeout(() => {
name.value = '李四';
age.value = 22;
}, 2000); watchEffect(() => {
console.log(name.value);
console.log(age.value);
});
return { name, age };
},
};

关闭监听

创建监听的时候可以用一个变量来接收watch或者watchEffect函数的返回值,然后在需要停止监听的地方调用这个匿名函数stop(),就可以关闭了

import { ref, watch, watchEffect } from 'vue';
export default {
setup() {
let name = ref('张三');
let age = ref(18); setTimeout(() => {
name.value = '李四';
age.value = 22;
}, 2000);
setTimeout(() => {
stop();//在这里关闭监听后,在4秒后就不会再打印信息了
name.value = '李四2';
age.value = 222;
}, 4000); let stop = watchEffect(() => {
console.log(name.value);
console.log(age.value);
});
return { name, age };
},
};

watchEffect和watch的区别

  1. watch默认是惰性的,只有当监听的变量发生改变时才会执行,watchEffect不是惰性的,组件初始化的时候就会执行,改变时也会执行。
  2. watch需要指定要监听的变量(ref和reactive类型的变量略不同),watchEffect不需要指定,在回调中使用到的响应式变量都会监听,当这些变量改变时,回调都会执行。
  3. watch可以再改变时获取到新值和旧值,watchEffect只能获取到新值。

Vue3全家桶升级指南一composition API的更多相关文章

  1. Vue3全家桶升级指南二ref、toRef、toRefs的区别

    ref是对原始数据的拷贝,当修改ref数据时,模板中的视图会发生改变,但是原始数据并不会改变. toRef是对原始数据的引用,修改toRef数据时,原始数据也会发生改变,但是视图并不会更新. 在vue ...

  2. 助你上手Vue3全家桶之Vue3教程

    目录 前言 1,setup 1.1,返回值 1.2,注意点 1.3,语法 1.4,setup的参数 2,ref 创建响应式数据 3,reactive 创建响应式数据 4,computed 计算属性 5 ...

  3. 基于 vite 创建 vue3 全家桶项目(vite + vue3 + tsx + pinia)

    vite 最近非常火,它是 vue 作者尤大神发布前端构建工具,底层基于 Rollup,无论是启动速度还是热加载速度都非常快.vite 随 vue3 正式版一起发布,刚开始的时候与 vue 绑定在一起 ...

  4. 助你上手Vue3全家桶之Vue-Router4教程

    目录 1,前言 1,Router 2.1,跳转 2.2,打开新页面 3,Route 4,守卫 4.1,onBeforeRouteLeave 4.2,onBeforeRouteUpdate 4.3,路由 ...

  5. 开箱即用 yyg-cli(脚手架工具):快速创建 vue3 组件库和vue3 全家桶项目

    1 yyg-cli 是什么 yyg-cli 是优雅哥开发的快速创建 vue3 项目的脚手架.在 npm 上发布了两个月,11月1日进行了大升级,发布 1.1.0 版本:支持创建 vue3 全家桶项目和 ...

  6. 助你上手Vue3全家桶之VueX4教程

    目录 1,前言 2,State 2.1,直接使用 2.2,结合computed 3,Getter 3.1,直接使用 3.2,结合computed 4,Mutation 4.1,直接使用 4.2,结合c ...

  7. vue3 vite2 封装 SVG 图标组件 - 基于 vite 创建 vue3 全家桶项目续篇

    在<基于 vite 创建 vue3 全家桶>一文整合了 Element Plus,并将 Element Plus 中提供的图标进行全局注册,这样可以很方便的延续 Element UI 的风 ...

  8. Vue3 全家桶,从 0 到 1 实战项目,新手有福了

    前端发展百花放,一技未熟百技出.未知何处去下手,关注小编胜百书. 我是前端人,专注分享前端内容! 本篇文章主要是,使用 vite 创建一个vue3 项目,实践 vie-router4 vuex4 结合 ...

  9. Windows Composition API 指南 - 认识 Composition API

    微软在 Windows 10中 面向通用 Windows 应用 (Universal Windows Apps, UWA) 新引入了一套用于用户界面合成的 API:Composition API.Co ...

随机推荐

  1. Linux信号与golang中的捕获处理

    什么是信号 在计算机科学中,信号是Unix.类Unix以及其他POSIX兼容的操作系统中进程间通讯的一种有限制的方式.它是一种异步的通知机制,用来提醒进程一个事件已经发生. 当一个信号发送给一个进程, ...

  2. 【转载】让KVM虚机能使用音箱与麦克风(vnc及ac97)

    让KVM虚机能使用音箱与麦克风(vnc及ac97) 原 tantexian 发布于 2016/02/29 16:32 字数 462 阅读 164 收藏 0 点赞 1 评论 0 为什么80%的码农都做不 ...

  3. Windows10查看电脑的USB接口是2.0还是3.0

    Windows10查看电脑的USB接口是2.0还是3.0原创小晓酱手记 最后发布于2019-08-22 16:09:48 阅读数 3662 收藏展开 同事要拷贝资料给我,问我电脑的USB接口是2.0还 ...

  4. 059.Python前端Django组件cooki和session

    一 会话跟踪技术 1.1 什么是会话 会话是指一个终端用户(服务器)与交互系统(客户端)进行通讯的过程. 1.2 什么是会话跟踪 对同一个用户对服务器的连续的请求和接受响应的监视.(将用户与同一用户发 ...

  5. 11.2 uptime:显示系统的运行时间及负载

    uptime命令可以输出当前系统时间.系统开机到现在的运行时间.目前有多少用户在线和系统平均负载等信息. [root@cs6 ~]# uptime   17:02:25 up 1:48, 3 user ...

  6. C语言函数sscanf()的用法-(转自Walter L)

    在我的学习过程中,从文件读取数据是一件很麻烦的事,所幸有sscanf()函数. C语言函数sscanf()的用法sscanf() - 从一个字符串中读进与指定格式相符的数据. 函数原型: int ss ...

  7. FreeBSD 13.0 正式版发布,已经可以下载

    请访问原文链接:https://sysin.org/article/freebsd-13/,查看最新版.原创作品,转载请保留出处. 根据 FreeBSD 13.0 官方发布计划,4 月 9 日 13. ...

  8. [论文阅读笔记] Unsupervised Attributed Network Embedding via Cross Fusion

    [论文阅读笔记] Unsupervised Attributed Network Embedding via Cross Fusion 本文结构 解决问题 主要贡献 算法原理 实验结果 参考文献 (1 ...

  9. Java日期时间API系列39-----中文语句中的时间语义识别(time NLP 输入一句话,能识别出话里的时间)原理分析

    NLP (Natural Language Processing) 是人工智能(AI)的一个子领域.自然语言是人类智慧的结晶,自然语言处理是人工智能中最为困难的问题之一(来自百度百科). 其中中文更是 ...

  10. ThreadLocal源码阅读笔记

    功能描述 ThreadLocal解决了访问共享变量的阻塞问题,并且不需要像CAS操作一样牺牲CPU资源,它为每一个线程维护了一个变量副本,每个线程在访问ThrealLocal里面的变量时实际上访问的是 ...