ElementPlus-Table表格-单选--TypeScript进阶篇

server/2024/10/21 7:57:30/

        今天看个例子,这个例子是ElementPlus的组件Table表格下面的单选

<template>
  <el-table
    ref="singleTableRef"
    :data="tableData"
    highlight-current-row
    style="width: 100%"
    @current-change="handleCurrentChange"
  >
    <el-table-column type="index" width="50" />
    <el-table-column property="date" label="Date" width="120" />
    <el-table-column property="name" label="Name" width="120" />
    <el-table-column property="address" label="Address" />
  </el-table>
  <div style="margin-top: 20px">
    <el-button @click="setCurrent(tableData[1])">Select second row</el-button>
    <el-button @click="setCurrent()">Clear selection</el-button>
  </div>
</template>

<script lang="ts" setup>
import { ref } from 'vue'
import { ElTable } from 'element-plus'

interface User {
  date: string
  name: string
  address: string
}

const currentRow = ref()
const singleTableRef = ref<InstanceType<typeof ElTable>>()

const setCurrent = (row?: User) => {
  singleTableRef.value!.setCurrentRow(row)
}
const handleCurrentChange = (val: User | undefined) => {
  currentRow.value = val
}
const tableData: User[] = [
  {
    date: '2016-05-03',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    date: '2016-05-02',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    date: '2016-05-04',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
  {
    date: '2016-05-01',
    name: 'Tom',
    address: 'No. 189, Grove St, Los Angeles',
  },
]
</script>

        注意到<script lang="ts" setup>,这个lang=”ts“表明其中的脚本解释会使用TypeScript。

        然后再看const singleTableRef = ref<InstanceType<typeof ElTable>>()这行,typeof ElTable表明会返回一个叫做ElTable名字的东西的类型,typeof类型运算符是JavaScript在表达式上下文中使用的运算符。typeof ElTable有可能会获得父类类型,那最终实例化的类型呢?

        答案就是由InstanceType<Type>这个工具类型来获得最终实例化的类型。构造一个由 Type 中的构造函数的实例类型组成的类型。那么InstanceType<typeof ElTable>>就是得到<el-table
    ref="singleTableRef">...</el-table>这个组件的类型。

        ref是一个泛型函数,能捕获参数类型的函数,表现得能接收多种类型参数的函数。ref<InstanceType<typeof ElTable>>(),这样写就表明ref现在是接收<el-table
    ref="singleTableRef">组件类型的参数的函数

        最终写成const singleTableRef = ref<InstanceType<typeof ElTable>>(),那么就表示singleTableRef是接收<el-table
    ref="singleTableRef">组件类型的参数的函数返回的对象

        最后我们再看看如下方法

const setCurrent = (row?: User) => {
  singleTableRef.value!.setCurrentRow(row)
}

        row?: User表示row参数可能存在,也可能不存在,参数类型是User。

        singleTableRef.value!这样写表明接收<el-table
    ref="singleTableRef">组件类型的参数的函数返回的对象的value值不能是null或者undefined,!在这里是个非空断言运算符

        ElementPlus是基于vue3写的UI框架,而vue3是用TypeScript写的javascript框架,在ElementPlus中既可以写vue3,也可以写TypeScript


http://www.ppmy.cn/server/133581.html

相关文章

IntelliJ IDEA中配置scala

1.IDEA中 配置 maven 左上角 file -> Setting 选择(或直接搜maven) Build, Execution,Deployment -> Build Toos -> Maven Maven home path 选择 maven 安装目录&#xff08;bin的上层目录&#xff09; 示例&#xff1a; D:\maven\apache-maven-3.8.6 User settings…

从 Microsoft 官网下载 Windows 10

方法一&#xff1a; 打开 Microsoft 官网&#xff1a; 打开开发人员工具&#xff08;按 F12 或右键点击“检查”&#xff09;。 点击“电脑模拟手机”按钮&#xff0c;即下图&#xff1a; 点击后重新加载此网页&#xff0c;即可看到下载选项。

Midjourney中文版:创意无界,绘梦成真

在数字艺术的浩瀚宇宙中&#xff0c;Midjourney中文版如同一颗璀璨的新星&#xff0c;以其独特的魅力和无限可能&#xff0c;引领着每一位创作者探索创意的无限边界。作为专为国内用户打造的AI绘画工具&#xff0c;Midjourney中文版不仅继承了原版的核心优势&#xff0c;更在本…

C++游戏开发入门:用 SDL 实现你的第一个 2D 游戏

前言 C 是游戏开发中广泛使用的编程语言&#xff0c;尤其在需要控制底层硬件性能的场景中&#xff0c;如 3D 引擎或实时物理模拟。在这篇文章中&#xff0c;我们将介绍如何使用 SDL&#xff08;Simple DirectMedia Layer&#xff09;进行 C 2D 游戏开发。SDL 是一个轻量级、跨…

【力扣 | SQL题 | 每日4题】力扣1164,3293,1308,1270

4 mid&#xff0c;四题都比较简单&#xff0c;没什么难度。 1. 力扣1164&#xff1a;指定日期的产品价格 1.1 题目&#xff1a; 产品数据表: Products ------------------------ | Column Name | Type | ------------------------ | product_id | int | | new_p…

UE4 材质学习笔记10(程序化噪波/覆雪树干着色器/岩层着色器)

一.程序化噪波 柏林噪波是一种能生成很好的随机图案的算法&#xff0c;它是一个无限的、不重复的图案&#xff0c;可以采用这种基础图案并以多种方式对其进行修改&#xff0c; 将它缩放并进行多次组合&#xff0c;就可以创建一个分形图案。这些组合的缩放等级称为一个Octave 这…

缓存区是什么

文章目录 前言一、数据传输二、异步操作三、性能优化四、大小和管理五、应用场景总结 前言 缓存区&#xff08;Buffer&#xff09;是计算机系统中用于临时存储数据的一块内存区域。它的主要作用是提高数据处理效率&#xff0c;解决生产者和消费者之间的速度差异。以下是缓存区…

网络安全的挑战与对策:从技术防御到综合治理的全方位分析

引言 随着互联网的迅猛发展,网络安全已成为全球关注的焦点之一。网络技术的进步为社会带来了巨大的经济、文化和科技红利,但也使得信息系统面临越来越复杂的安全威胁。网络攻击的种类日益多样化、攻击技术日益成熟化,给个人、企业、政府以及关键基础设施带来了严重的安全挑…