vue3+ts组件练习(defineExpose defineEmits defineProps)

news2025/2/26 9:48:49

学习关键语句:
vue3+ts 组件写法

写在前面

进化到 vue3 + ts 的时代,vue的不少语法发生了改变,尤其是选项式 API 变为了组合式 API 和 typescript 的使用使得从 vue2 过来的人需要尽快熟悉新的写法,毕竟大差不差嘛

文章最后有本文使用项目文件链接

这篇文章练习的点共有三个:

defineExpose => 组件向外暴露的自身的属性和方法

defineEmits => 组件向外暴露的自定义方法

defineProps => 组件可以传入的值

我们将一个一个来练习使用

开始

我们先使用 vite 创建一个工程项目 我起名为 practice-app

npm create vite

如下图选择就可以完成创建,再根据提示 cd practice-app 安装依赖之后就可以运行了
在这里插入图片描述
接下来,打开项目目录 src 打开 App.vue 将里面的内容替换成空白
在这里插入图片描述
在这里插入图片描述
之所有会有样式是因为引入了 src 下的 style.css 文件,如果你不感冒,可以清空里面的样式,作为练习我无动于衷(™这是在说啥)

创建一个测试用例组件

在 components 文件下新建文件 YaHooTest.vue
写一点基础的东西,然后就在 App.vue 文件引入后就准备开始练习了
在这里插入图片描述
在这里插入图片描述

defineExpose

defineExpose 可以向外暴露组件的属性值和方法,我们一个一个来测试

属性值

我们先简单写好一个输入框,将输入框的值作为向外暴露的属性值

App.vue

<template>
  <h1>hello 邵雅虎</h1>
  <hr>
  <ya-hoo-test ref="testRef"></ya-hoo-test>
  <br>
  <button @click="conInput">打印输入框的内容</button>
</template>

<script setup lang="ts">
import { ref } from 'vue' 
import YaHooTest from './components/YaHooTest.vue';

const testRef = ref(null)
const conInput = () => {
  console.log(testRef.value.txt)
}
</script>

<style scoped>

</style>

YaHooTest.vue

<template>
  <div>你好,邵雅虎</div>
  输入框:<input type="text" v-model="txt">
</template>

<script setup lang="ts">
import { ref } from 'vue' 

let txt = ref('')

defineExpose({
  txt
})
</script>

<style scoped>

</style>

在这里插入图片描述
在这里插入图片描述
这个文字内容完全是属于组件的一部分,和父组件是一点关系都没有,但是通过 defineExpose 的方式可以将子组件的属性值进行显示

方法

那么我们接下来向外暴露方法

我们简单写一个 显示/隐藏 子组件内容人物信息卡的方法,其中,人物信息卡的内容我们暂时写死,之后再通过 defineProps 从父组件获取

App.vue

<template>
  <h1>hello 邵雅虎</h1>
  <hr>
  <ya-hoo-test ref="testRef"></ya-hoo-test>
  <br>
  <button @click="conInput">打印输入框的内容顺便打开人物信息卡</button>
</template>

<script setup lang="ts">
import { ref } from 'vue' 
import YaHooTest from './components/YaHooTest.vue';

const testRef = ref(null)
const conInput = () => {
  console.log(testRef.value.txt)
  testRef.value.openPerson()
}
</script>

<style scoped>

</style>

YaHooTest.vue

<template>
  <div>你好,邵雅虎</div>
  <div v-if="showPerson" style="backgroundColor:black;color:white">
    <h3>人物信息卡</h3>
    <h5>姓名:邵雅虎</h5>
    <h5>年龄:18</h5>
    <h5>爱好:唱、跳、rap</h5>
    <button @click="closePerson">关闭</button>
  </div>
  输入框:<input type="text" v-model="txt">
</template>

<script setup lang="ts">
import { ref } from 'vue'

let txt = ref('')
let showPerson = ref(false)
// 打开人物信息卡
const openPerson = () => {
  showPerson.value = true
}
// 关闭人物信息卡
const closePerson = () => {
  showPerson.value = false
}

defineExpose({
  txt,
  openPerson
})
</script>

<style scoped>

</style>

在这里插入图片描述
这样一来就可以通过子组件提供的方法来打开人物信息卡了
在这里插入图片描述

defineProps

接下来我们来测试 defineProps 这个东东
我们将之前的人物信息卡里面的信息通过父组件传递进来

App.vue

<template>
  <h1>hello 邵雅虎</h1>
  <hr>
  <ya-hoo-test ref="testRef" :person="p"></ya-hoo-test>
  <br>
  <button @click="conInput">打印输入框的内容顺便打开人物信息卡</button>
</template>

<script setup lang="ts">
import { ref } from 'vue'
import YaHooTest, { Person } from './components/YaHooTest.vue';

const testRef = ref(null)
const conInput = () => {
  console.log(testRef.value.txt)
  testRef.value.openPerson()
}
let p: Person = {
  name: '邵雅虎',
  age: 18,
  hobby: ['唱', '跳', 'rap']
}

</script>

<style scoped>

</style>

YaHooTest.vue

<template>
  <div>你好,邵雅虎</div>
  <div v-if="showPerson" style="backgroundColor:black;color:white">
    <h3>人物信息卡</h3>
    <h5>姓名:{{ person.name }}</h5>
    <h5>年龄:{{ person.age }}</h5>
    <h5>爱好:<span v-for="(item, index) in person.hobby" :key="index">{{ item }}</span></h5>
    <button @click="closePerson">关闭</button>
  </div>
  输入框:<input type="text" v-model="txt">
</template>

<script setup lang="ts">
import { ref, PropType } from 'vue'
export interface Person {
  name: String,
  age: Number,
  hobby: Array<String>
}
let txt = ref('')
let showPerson = ref(false)
// 打开人物信息卡
const openPerson = () => {
  showPerson.value = true
}
// 关闭人物信息卡
const closePerson = () => {
  showPerson.value = false
}
defineExpose({
  txt,
  openPerson
})
defineProps({
  person: Object as PropType<Person>
})
</script>

<style scoped>

</style>

在这里插入图片描述

这样一来我们的值就从父组件传递到子组件当中去了,其中,我们用到了 ts 的泛型和类型断言

在这里插入图片描述

可以看到,显示效果和之前写死是一样的

defineEmits

那么接下来,我们就来写组件的自定义事件,组件向外暴露的方法

我们写一个当输入框的内容为 hello shaoyahu 的时候就弹出一个窗口的事件,当然了,为了好看一些,我决定将弹出事件延迟100毫秒

我们使用监听器来判断输入框的内容是否是我们想要的值

App.vue

<template>
  <h1>hello 邵雅虎</h1>
  <hr>
  <ya-hoo-test ref="testRef" :person="p" @say="fn"></ya-hoo-test>
  <br>
  <button @click="conInput">打印输入框的内容顺便打开人物信息卡</button>
  <h3>当输入框的内容为 hello shaoyahu 时会暴富</h3>
</template>

<script setup lang="ts">
import { ref } from 'vue'
import YaHooTest, { Person } from './components/YaHooTest.vue';

const testRef = ref(null)
const conInput = () => {
  console.log(testRef.value.txt)
  testRef.value.openPerson()
}
let p: Person = {
  name: '邵雅虎',
  age: 18,
  hobby: ['唱', '跳', 'rap']
}
const fn = () => {
  alert('借你吉言!')
}
</script>

<style scoped>

</style>

YaHooTest.vue

<template>
  <div>你好,邵雅虎</div>
  <div v-if="showPerson" style="backgroundColor:black;color:white">
    <h3>人物信息卡</h3>
    <h5>姓名:{{ person.name }}</h5>
    <h5>年龄:{{ person.age }}</h5>
    <h5>爱好:<span v-for="(item, index) in person.hobby" :key="index">{{ item }}</span></h5>
    <button @click="closePerson">关闭</button>
  </div>
  输入框:<input type="text" v-model="txt">
</template>

<script setup lang="ts">
import { ref, PropType, watch } from 'vue'
export interface Person {
  name: String,
  age: Number,
  hobby: Array<String>
}
let txt = ref('')
let showPerson = ref(false)
// 打开人物信息卡
const openPerson = () => {
  showPerson.value = true
}
// 关闭人物信息卡
const closePerson = () => {
  showPerson.value = false
}
// 监听输入框的值
watch(txt, (newV, oldV) => {
  if (newV.toString() == 'hello shaoyahu') {
    setTimeout(() => {
      emit('say')
    }, 100);
  }
})
defineExpose({
  txt,
  openPerson
})
defineProps({
  person: Object as PropType<Person>
})
const emit = defineEmits(['say'])
</script>

<style scoped>

</style>

在这里插入图片描述
OK ,那么效果就是这样一个效果了,我们成功的触发了我们的自定义事件

结束

这篇文章的内容确实也比较少,但是只要是写过 vue2 组件的朋友只需要看看这几个新的写法就可以上手了,毕竟其他的东西和 vue2 时期相差不大,当然了,我觉得相差不大也可能是因为我比较菜,谢谢你的观看希望都能有所收获

文件链接

同样的,这个练习的链接我也放在这里,和之前一样,都是免费的,毕竟也没啥值钱的东西嘛

https://download.csdn.net/download/shaoyahu/87035327

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/9918.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

图像分割 - 阈值处理 - 全局阈值处理

目录 1. 介绍 2. 代码实现 3. 代码讲解 1. 介绍 当目标和背景像素的灰度分布非常不同的时候&#xff0c;可以对整个图像使用全局阈值 在大多数的应用中&#xff0c;图像之间通常存在足够的变化&#xff0c;全局阈值是一种合适的办法。所以&#xff0c;需要一种对图像做阈值…

生存分析的图你也要拼接 图形拼接r 不同的图形组合在一起

生存分析的图你也要拼接吗 因为都是ggplot体系的图表,很容易拼接,但是里面的生存分析是一个麻烦事情。因为它本身主要是survminer包出图,而这个survminer包出图并不是很稳定,但是学员自己解决了这个问题。 可以先用survminer包的arrange_ggsurvplots函数对多个生存分析图表…

CUDA By Example(五)——常量内存与事件

本章将介绍如何使用GPU上特殊的内存区域来加速应用程序的执行&#xff0c;以及如何通过事件来测量CUDA应用程序的性能。通过这些测量方法&#xff0c;你可以定量的分析对应用程序的某个修改是否会带来性能提升 文章目录常量内存光纤跟踪简介在GPU上实现光线跟踪通过常量内存来实…

[附源码]java毕业设计家庭医生系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Java代码审计——WebGoat XML外部实体注入(XXE)

目录 前言&#xff1a; 0x01 Let’s try 0x02 代码分析 2.1 安全的代码 0x03 Modern REST framework 3.1 解题&#xff1a; 3.2 改为xml格式: 3.3 源码分析&#xff1a; 3.4 参考解决方案 0x04 Blind XXE assignment 0x05XXE DOS attack 参考文章&#xff1a; 前言…

“百花齐放、百家争鸣”,数据可视化呈现我国科学文化的发展

公共财政对文化建设的支持日益加强&#xff0c;公共文化设施不断完善&#xff0c;覆盖城乡的公共文化服务网络初步建立&#xff0c;公共文化服务理念逐步深化&#xff0c;公共文化服务能力和均等化水平逐渐提高&#xff1b;文化产业投资向发展水平较低的中西部地区倾斜&#xf…

node.js+Express框架,前端自己创建接口

目录 一、安装 1、安装node.js 2、安装Express框架 3、安装nodemon 二、写接口 三、连接数据库 1、安装&#xff1a; 2、连接数据库 3、执行 四、注意事项 1、跨域 这篇文章看完如果您觉得有所收获&#xff0c;认为还行的话&#xff0c;就点个赞收藏一下呗 一、安装…

多线程详细介绍

一、分类 创建线程的四种方法&#xff1a; &#xff08;1&#xff09;继承Thread &#xff08;2&#xff09;实现Runnable &#xff08;3&#xff09;实现Callable &#xff08;4&#xff09;线程池创建一个新的线程可以通过继承Thread类或者实现Runnable接口来实现&#xff0…

JAVA基础—面向对象

1、面向对象介绍 2、类和对象 2.1、如何定义类、得到类的对象、使用对象 2.2、类和对象的总结 2.3、定义类的补充事项—测试类与Javabean类 成员变量一般无需指定初始值&#xff0c;存在默认值。 但是局部变量必须定义初始值。 2.4、定义类的注意事项 2.4.1、驼峰模式 单词…

容器docker安装,以及paddle容器环境安装

例如 一台新的 服务器部署环境 1.环境服务器部署 第一步:查看显卡的驱动是否装好了,可以用nvidia-smi,正常显示表示已经安装 上面版本没有问题,但是下面版本驱动本本比较低,不支持11.2cuda安装,要更新驱动 docker, nvidia-docker 安装之前先确认如下三个 paddle 2.3 …

Win11 KB5019157(22000.1281)11月累积补丁推送了!

微软在最新推出的KB5019157更新补丁中修复了Microsoft Store更新等多个错误&#xff0c;但是仍然存在Direct Access问题。Win11用户安装之后即可升级至22000.1281&#xff0c;下面就来看看详细内容。 重要信息 KB5019157累积更新补丁 它解决了 Microsoft Store 的一些持续更新失…

shell中通配符的使用

shell中的通配符与正则表达式是不同的两种功能。 正则表达式一般不会在bash直接应用&#xff0c;需要使用sed、grep、awk来解释正则表达式。 通配符则可以通过bash直接解释&#xff0c;一般用作名称展开。 bash中可以使用的通配符符号包括&#xff1a;*、?、{}、[]、^ 这些…

【环境配置笔记】基于clang15搭建liunx内核代码阅读环境

环境&#xff1a; Toolchain&#xff08;yocto导出&#xff09;Linux5-15&#xff0c;arm64VS codeclangd15.0.3 1. VScode配置 在VS code / VS code server中配置以下插件&#xff1a; ClangdC/CC/C Extension PackC/C SnippetsCode RunnerCode Spell CheckercompareitDev…

拖拽页面元素+flip动画的案例

先上效果&#xff1a; 实现思路和流程&#xff1a; 基础页面布局 给每个拖动元素加上 draggable"true"ondragstart(开始拖动某个元素时)做出 对应的处理 获得操作的具体元素 给目标元素添加对应的样式 显示透明 增加虚线描边ondragover 被拖动的元素hover到目标元素…

java计算机毕业设计ssm养老管理系统-敬老院系统

项目介绍 1.登录页面要有验证码 2.在健康信息模块中有三个小模块分别是饮食信息、身体信息、医疗常识,饮食信息就是护工每天负责老人的饮食搭配包括;早中晚餐;各种菜谱、图片、注意事项等,身体信息就是老人的各项身体指标,医疗常识就是每一种病对应一种病例还有每天推送更新的关…

互联网获客经验分享(一)

现在的流量都很贵了。特别是公域的流量。在这样的情况下,我们如何从互联网上获取客户?满足我业务的需求呢。 今天为大家分享基础的方法,后续我们会不定期的分享一些互联网软件获客的经验,希望能够帮助到你。 流量的本质 不管是平台方还是用户,流量都是生命线。在这样的…

好心情心理咨询平台:独处≠孤独,独处对心理健康有多重要?

说到独处&#xff0c;有人认为那不就是自己一个人呆着嘛。 非也非也&#xff0c;独处其实不是要求远离人群&#xff0c;而是在信息与情感上与他人无交流&#xff0c;做到无社会互动&#xff0c;与人在网上聊天、打电话可都不能算是独处。 相反&#xff0c;自己一个人在图书馆…

ClickHouse Senior Course Ⅳ

序言 梳理一下ClickHouse的数据库引擎 首先了解下什么是数据库引擎(cuiyaonan2000163.com) 数据库引擎是用于存储、处理和保护数据的核心服务。利用数据库引擎可控制访问权限并快速处理事务&#xff0c;从而满足企业内大多数需要处理大量数据的应用程序的要求。 使用数据库引…

[附源码]java毕业设计健身房管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

《无障碍环境认证实施方案》发布

市场监管总局 中国残联关于印发 《无障碍环境认证实施方案》的通知 国市监认证发〔2022〕94号各省、自治区、直辖市和新疆生产建设兵团市场监管局&#xff08;厅、委&#xff09;、残联&#xff0c;各有关单位&#xff1a;现将《无障碍环境认证实施方案》印发给你们&#xff0…