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. centos7安装powershell和powercli

    poershell github https://github.com/PowerShell/PowerShell/releases 本次采用github下载对应的rpm进行安装 windows下安装 ...

  2. tar解压某个目录 tar解压某个指定的文件或者文件夹

    tar解压某个目录 tar解压某个指定的文件或者文件夹 发布时间:2017-05-30 来源:服务器之家   1. 先查看压缩文档中有那些文件,如果都不清楚文件内容,然后就直接解压,这个是不可能的 使 ...

  3. 有没有一种组合字体,中文是宋体,英文是times new roman?

    有没有一种组合字体,中文是宋体,英文是times new roman? 由于日常科研工作书写需要,想问问各位大神有没有一种字体,中文是宋体,西文是times new roman,这样写论文好方便啊有没 ...

  4. Scala 神奇的下划线 _

    引言 在 Scala 中,下划线 _ 有很多种用法,作为 Scala 初学者也经常被下划线 _ 搞得晕头转向,下面是对 Scala 中下划线 _ 使用的简单总结~ 导包时, 下划线 _ 表示引用多个方 ...

  5. 文件包含之包含了Linux文件描述符

    0x00 原理   文件描述符是内核为了高效管理已被打开的文件所创建的索引,用于指向被打开的文件,所有执行I/O操作的系统调用都通过文件描述符. 翻译成人话- 可以认为是指向文件的一个指针,如果有文件 ...

  6. 3分钟 Markdown 快速入门(超详细)(Day_33)

    Markdown 快速入门 (这个贼重要)注:所有符号要在英文状态下完成哦,中文是没有效果的. 1.标题 # 表示一级标题 ## 表示二级标题 ### 表示三级标题 #### 表示四级标题 ##### ...

  7. EasyUI_使用datagrid分页 (Day_28)

    本次分页涉及技术点 SSM+PageHelper+DatagrId 先来看下效果: 这是无条件分页,下一篇博客我们将讲有条件分页. 无论你是使用js加载table 还是直接使用标签. 使用datagr ...

  8. JavaScript正则表达式(深度)(Day_14)

    忘不掉的是回忆,继续的是生活,错过的,就当是路过. 简介 正则表达式是用于匹配字符串中字符组合的模式.在 JavaScript中,正则表达式也是对象. 这些模式被用于 RegExp 的 exec 和  ...

  9. 达梦数据库产品支持技术学习分享_Week2

    本周主要从以下几个方面进行本人对达梦数据库学习的分享,学习进度和学习情况因人而异,仅供参考. 一.文本命令行工具使用的方法(Disql和dmfldr) 二.数据库备份 三.定时作业功能 四.系统表和动 ...

  10. Linux - last 命令

    前言 为啥写这篇?因为听 grep.sed 教程的时候有这个命令 栗子 加上工作中,运维给我排查问题的时候也用到了,感觉挺重要,先了解为敬! 命令作用 显示上次登录用户的列表 这个是在 Linux 下 ...