关于typescript中as的用法

发布于 2022-09-12 22:52:55 字数 302 浏览 12 评论 0

在Ant design pro的用户登录文件 src/models/login.ts中看到一条代码
let { redirect } = params as { redirect: string };

其中

const params = getPageQuery();
export const getPageQuery = () => parse(window.location.href.split('?')[1]);

不太理解第一条代码什么意义,想请假大家!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

撩心不撩汉 2022-09-19 22:52:55

as 是ts里定义类型的意思

// 其实params是这样的解构
params = {
    redirect: 'xxx'
}

let { redirect } = params as { redirect: string };
这里的意思是说params的类型是个object 并且里面有一个redirect的属性是string类型的

let { redirect } = params;前半段是解构赋值取params.redirect
params as { redirect: string };后半段是给params定义类型

雨落□心尘 2022-09-19 22:52:55

let { redirect } = params;
这是从params中取出redirect的属性和value

as { redirect: string }
as可以理解成当作的意思,就是把params当作{ redirect: string }
只不过这里规定了redirectstring类型。

这是一种约束类型的方式,避免你把redirect当成number/boolean等其他类型来用。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文