首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何将类型化变量用作类型记录中同名的类型?

如何将类型化变量用作类型记录中同名的类型?
EN

Stack Overflow用户
提问于 2021-02-08 16:42:46
回答 1查看 1.2K关注 0票数 0

当使用THREE.js和类型记录时,您可以对类型和代码使用相同的名称。例如:

代码语言:javascript
运行
复制
import * as THREE from '/build/three.module.js'

// Following line uses THREE.Scene as type and code
const scene: THREE.Scene = new THREE.Scene()

演示

Im 试图在我自己的代码中复制相同的行为,但不确定如何做到。这就是我尝试过的:

代码语言:javascript
运行
复制
// typedModule.ts

export const typedConstant1: string = "string";

// Doesnt work
// declare global {
//     namespace typedModule {
//       export type typedConstant1 = typeof typedConstant1
//     }
//   }
代码语言:javascript
运行
复制
// index.ts

import * as typedModule from "./typedModule";

const someVariable: typedModule.typedConstant1 = typedModule.typedConstant1; // ERROR: Namespace '"/sandbox/src/typedModule"' has no exported member 'typedConstant1'.ts(2694)

演示

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-08 16:49:12

您应该能够以导出值的方式导出类型:

代码语言:javascript
运行
复制
export const typedConstant1: string = "string";
export type typedConstant1 = typeof typedConstant1;

然后进口应起作用:

代码语言:javascript
运行
复制
import * as typedModule from "./typedModule";

const someVariable: typedModule.typedConstant1 = typedModule.typedConstant1;
// const someVariable: string

改进型码箱演示

TS游乐场中的类似代码

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66105716

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档