typescript interface定义数组每一项都为对象

定义一个方法,返回一个数组,数组的每一项均为对象,对象中包含label和value两个属性

创建一个public.ts文件

javascript实现

// javascript 实现
export const formatYear = function () {
	let date = new Date().getFullYear();
	let arr = [];
	for (let i = 0; i < date + 10; i++) {
		arr.push({
			label: i,
			value: i
		})
	}
    return arr;
}

typescript实现

// 定义一个接口约束label和value值类型

interface labelValue {
	label: number;
	value: number;
}
let obj: labelValue;
export function formatYear (): labelValue[] {
	let date = new Date().getFullYear();
	let arr: labelValue[];
	for (let i = 0; i < date + 10; i++) {
		obj = {
			label: i,
			value: i
		}
		arr.push(obj)
	}
	return arr;
}

typescript 类型兼容

在public文件中再定义一个方法,也返回一个数组,但是label类型变为string

由于ts文件中label属性只能声明一次

所以需要用到类型变量来实现

T 表示传入的类型,可以为number、string、boolean等
传入什么label就是什么类型
interface labelValue<T> {
	label: T;
	value: number;
}
// 传入number类型
let obj: labelValue<number>;
export function formatYear (): labelValue<number>[] {
	let date = new Date().getFullYear();
	let arr: labelValue<number>[];
	for (let i = 0; i < date + 10; i++) {
		obj = {
			label: i,
			value: i
		}
		arr.push(obj)
	}
	return arr;
}

// 传入string类型
let obj1: labelValue<string>;
export function formatHours (): labelValue<string>[] {
	let arr: labelValue<string>[];
	for (let i = 0; i <= 24 + 10; i++) {
		obj1 = {
			label: i + 'h',
			value: i
		}
		arr.push(obj1)
	}
	return arr;
}

 

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值