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

今天看个例子,这个例子是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

相关推荐
唐懒猫17 小时前
使用 HTML + JavaScript 实现手写签名功能
前端·javascript·html
亿元程序员17 小时前
其实Creator里面这个裁剪代码的功能很好用,建议试试
前端
感谢地心引力17 小时前
【Chrome-Edge-Firefox】浏览器插件开发
前端·chrome·edge·firefox
qq_2965446517 小时前
安卓版Google(谷歌地球),安卓谷歌(Google)地图,谷歌翻译,谷歌(Chrome)浏览器,手机版Edge,浏览器等安卓版浏览器下载
前端·chrome
今天也想MK代码17 小时前
JS 注入机制深度解析
java·前端·javascript
一字白首17 小时前
Vue 进阶,指令补充 + computed+watch
前端·javascript·vue.js
暮之沧蓝17 小时前
React(18-19)总结
前端·react.js·前端框架
计算机学姐17 小时前
基于Python的旅游数据分析及可视化系统【2026最新】
vue.js·python·数据挖掘·数据分析·django·旅游·推荐算法
HIT_Weston17 小时前
50、【Ubuntu】【Gitlab】拉出内网 Web 服务:http.server 单/多线程分析(二)
前端·ubuntu·gitlab
我太想进步了C~~17 小时前
Prompt Design(提示词工程)入门级了解
前端·人工智能·算法