从新回归Vue之3.0(二):setup,defineProps,defineEmits,变量,defineExpose

本文主要是介绍从新回归Vue之3.0(二):setup,defineProps,defineEmits,变量,defineExpose,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.在setup()中不能用this

在vue2.x里飞天遁地的this没有了,因为

`setup` 的调用发生在 `data` 、`computed` 或 `methods` 被解析之前,所以它们无法在 `setup` 中被获取,这也是为了避免setup()和其他选项式API混淆。

二.setup推荐用法

<template><h1>{{ msg }}</h1>
</template><script setup lang="ts">
import { ref } from "vue";
</script><style scoped>
</style>

注意点:

  • 在setup语法糖中导入组件不需要注册声明,直接在视图中使用即可;
  • 默认的vue文件结构发生改变,js默认放到页面顶部,而视图template放到js下面,style放到页面底部;
  • 导入vue文件必须写上文件后缀名.vue, 否则ts无法识别vue文件。
  • vscode插件不要用vue-format,会导致setup申明消失。

三.defineProps和defineEmits的用法

`defineProps` 和 `defineEmits` API,它们在 `<script setup>` 中都是自动可用的:

defineProps类似之前的props属性

defineEmits类似之前的this.$emit('xxx')的用法

父组件

<template><HelloWorld :msg="msg" @handleClick="handleClick"/>
</template><script setup lang="ts">
import { ref } from 'vue';
import HelloWorld from './components/HelloWorld.vue'
//data
const msg = ref('欢迎使用vite!')
//methods
const handleClick = (params)=>{console.log(params);
}
</script>

 子组件

<template><h1>{{ msg }}</h1><button @click="handleClick">点击我调用父组件方法</button>
</template><script setup lang="ts">
import { ref } from "vue";
// props
const props = defineProps({msg: {type: String,default: "",},
});
// emit
const emit = defineEmits(["handleClick"]);
// methods
const handleClick = () => {emit("handleClick", "父组件方法被调用了");
};
</script>

四,如何创建变量

import { ref,reactive } from "vue";
// data
let a = ref(2)//ref用来创建基本数据类型
let obj = reactive({name: '张三', age: 2300})//reactive用来创建复杂数据类型
let arr = reactive(['1', '2', '3'])

五.defineExpose的用法

在vue2.x中我们可以通过this.$refs.xxx或者 this.$parent 链获取到的组件的公开实例,

但是使用 <script setup> 的组件是默认关闭的,

为了在 <script setup> 组件中明确要暴露出去的属性,使用 defineExpose 。

假如我们要在子组件里暴露一个handleClick2方法,我们要先定义这个方法

const handleClick2 = () => {a.value = 3obj.name = '我叫改变'
};

然后整个<script setup> 的最下边用

// defineExpose 统一暴露
defineExpose({a,obj,handleClick2
})

因为如果defineExpose代码行在上,handleClick2申明在下,会报错

这篇关于从新回归Vue之3.0(二):setup,defineProps,defineEmits,变量,defineExpose的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/801357

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

Python之变量命名规则详解

《Python之变量命名规则详解》Python变量命名需遵守语法规范(字母开头、不使用关键字),遵循三要(自解释、明确功能)和三不要(避免缩写、语法错误、滥用下划线)原则,确保代码易读易维护... 目录1. 硬性规则2. “三要” 原则2.1. 要体现变量的 “实际作用”,拒绝 “无意义命名”2.2. 要让

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

vue监听属性watch的用法及使用场景详解

《vue监听属性watch的用法及使用场景详解》watch是vue中常用的监听器,它主要用于侦听数据的变化,在数据发生变化的时候执行一些操作,:本文主要介绍vue监听属性watch的用法及使用场景... 目录1. 监听属性 watch2. 常规用法3. 监听对象和route变化4. 使用场景附Watch 的

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路