typeScript(九)泛型

什么时候需要用泛型

  • 标注的具体类型并不能确定,比如一个函数的参数类型:
function getVal(obj, k) { 
	return obj[k]; 
}
  • 上面的函数,想实现的是获取一个对象指定的 k 所对应的值,那么实际使用的时候,obj 的类型是不确定的,自然 k 的取值范围也是不确定的,它需要我们在具体调用的时候才能确定,这个时候这种定义过程不确定类型的需求就可以通过泛型来解决

泛型在函数中的使用

function getVal<T>(obj: T, k: keyof T) { 
	return obj[k]; 
}
let obj1 = {
    x: 1,
    y: 2
}
let obj2 = {
    username: 'xiaochen',
    age: 25
}
getVal<typeof obj1>( obj1, 'x' );
getVal<typeof obj2>( obj2, 'age' );
  • 所谓的泛型,就是给可变(不定)的类型定义变量(参数), <> 类似 ()

泛型在类中的使用

  • 基于泛型使用的模拟组件:
abstract class Component<T1, T2> { 
	props: T1; 
	state: T2; 
	constructor(props: T1) { 
		this.props = props; 
	}
	abstract render(): string;
}
interface IMyComponentProps { 
	val: number; 
}
interface IMyComponentState { 
	x: number; 
}
class MyComponent extends Component<IMyComponentProps, IMyComponentState> { 		
	constructor(props: IMyComponentProps) { 
		super(props); 
		this.state = { x: 1 } 
	}
	render() { 
		this.props.val; 
		this.state.x; 
		return '<myComponent />'; 
	} 
}
let myComponent = new MyComponent({val: 1}); 
myComponent.render(); 

泛型在接口中的使用

  • 后端提供了一些接口,用以返回一些数据,依据返回的数据格式定义如下接口:
interface IResponseData { 
	code: number; 
	message?: string; 
	data: any; 
}
  • 根据接口,封装对应的一些方法
function getData(url: string) { 
	return fetch(url).then(res => { 
		return res.json(); 
	}).then( (data: IResponseData) => { 
		return data; 
	}); 
}
  • 但是,会发现该接口的 data 项的具体格式不确定,不同的接口会返回的数据是不一样的,根据具体当前请求的接口返回具体 data 格式的时候,就比较麻烦了,因为 getData 并不清楚调用的具体接口是什么,对应的数据又会是什么样的
  • 这个时候我们可以对 IResponseData 使用泛型
interface IResponseData<T> { 
	code: number; 
	message?: string; 
	data: T; 
}
function getData<U>(url: string) { 
	return fetch(url).then(res => { 
		return res.json(); 
	}).then( (data: IResponseData<U>) => { 
		return data; 
	}); 
}
  • 定义不同的数据接口
// 用户接口 
interface IResponseUserData { 
	id: number; 
	username: string; 
	email: string; 
}
// 文章接口 
interface IResponseArticleData { 
	id: number; 
	title: string; 
	author: IResponseUserData; 
}
  • 调用具体代码
~(async function(){ 
	let user = await getData<IResponseUserData>(''); 
	if (user.code === 1) { 
		console.log(user.message); 
	} else { 
		console.log(user.data.username); 
	}
	let articles = await getData<IResponseArticleData>(''); 
	if (articles.code === 1) { 
		console.log(articles.message); 
	} 
	else { 
		console.log(articles.data.id); 
		console.log(articles.data.author.username); 
	} 
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
此版本更新内容包括:Feature :sparkles: 新增 sortBy 和 topAndOther filter (#1378) (#1379) api 新增 responseData 配置 (#1379) 添加季度选择器 Quarter (#1382) Container 支持设置样式 (#1411) 加入 ecStat, Apache ECharts (incubating) 的统计和数据挖掘工具 (#1419) Form 支持 feedback (#1420) 新增仿 antd 主题 (#1421) Enhancement jssdk 支持外部监控路由变化重新切换页面 (#1373) 选择类表单项 selectFirst 跳过 disabled 的选项 (#1393) iconfont 发布到 sdk 里 (#1395) api mock 地址替换 (#1408) Echarts 没数据时显示 loading (#1409) Breaking :翻译文件的 key 不再是中文,如果有修改过英文翻译,需要换成新 key (#1416) (#1418) 拆解 factory.tsx,添加 RootRenderer,并能 处理部分 action, 直接渲染个按钮也能弹窗,发ajax了 (#1425) Text 配置 source 样式优化 (#1429) 更换 autobind,继承时 this 不错乱 (#1433) Bugfix 修复 表单项在不配置 name 的时候,value 属性失效问题 (#1372) 修复 Excel 导出的列顺序依照配置的顺序,而不是数据源 (#1377) 修复 ChartRadios tooltip 问题. (#1378) 修复 位置选择组件在新版百度地图 api 下无法使用问题 (#1381) 修复 表单项有多个的时候,回车不提交问题 (#1387) 修复 helper 中 white-space 不正确问题 (#1390) 修复 Excel 导出不支持嵌套 name 和 tpl 问题 (#1424) 修复 收起状态导航菜单不可点击跳转问题 (#1428) 修复 Checkbox 无 disabled 样式问题 (#1414)amis前端低代码框架是一个低代码前端框架,它使用 JSON 配置来生成页面,可以节省页面开发工作量,极大提升开发前端页面的效率。 目前在百度广泛用于内部平台的前端开发,已有 100+ 部门使用,创建了 3w+ 页面。amis前端低代码框架特点1、不需要前端:在百度内部,大部分 amis 用户之前从来没写过前端页面,也不会 JavaScript,却能做出专业且复杂的后台界面,这是所有其他前端 UI 库都无法做到的; 2、不受前端技术更新的影响:百度内部最老的 amis 页面是 4 年多前创建的,至今还在使用,而当年的 Angular/Vue/React 版本现在都废弃了,当年流行的 Gulp 也被 Webpack 取代了,如果这些页面不是用 amis,现在的维护成本会很高; 3、享受 amis 的不断升级:amis 一直在提升细节交互体验,比如表格首行冻结、下拉框大数据下不卡顿等,之前的 JSON 配置完全不需要修改; 4、可以完全使用可视化页面编辑器 来制作页面:一般前端可视化编辑器只能用来做静态原,而 amis 可视化编辑器做出的页面是可以直接上线的。 5、提供完整的界面解决方案:其它 UI 框架必须使用 JavaScript 来组装业务逻辑,而 amis 只需 JSON 配置就能完成完整功能开发,包括数据获取、表单提交及验证等功能,做出来的页面不需要经过二次开发就能直接上线; 6、内置 100+ 种 UI 组件:包括其它 UI 框架都不会提供的富文本编辑器、条件组合等,能满足各种页面组件展现的需求,而且对于特殊的展现形式还可以通过 自定义组件 来扩充; 7、容器支持无限级嵌套:可以通过组合来满足各种布局需求; 8、经历了长时间的实战考验:amis 在百度内部得到了广泛使用,在 4 年多的时间里创建了 3 万+ 页面,从内容审核到机器管理,从数据分析到模训练,amis 满足了各种各样的页面需求,最复杂的页面有超过 1 万行 JSON 配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值