位置: IT常识 - 正文

TypeScript选项‘importsNotUsedAsValues‘和‘preserveValueImports‘弃用(typescriptlang)

编辑:rootadmin
TypeScript选项‘importsNotUsedAsValues‘和‘preserveValueImports‘弃用

推荐整理分享TypeScript选项‘importsNotUsedAsValues‘和‘preserveValueImports‘弃用(typescriptlang),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:typescript instanceof,typescript enum,typescriptreact,typescript import,typescript implements,typescript import,typescript enum,typescript import,内容如对您有帮助,希望把文章链接给更多的朋友!

TypeScript 从5.0开始,选项“importsNotUsedAsValues”和“preserveValueImports”已经被标记为Deprecated,并将在TypeScript5.5之后停止支持,可以使用“verbatimModuleSyntax”选项替代。

默认情况下,假如你在TypeScript中写下如下代码:

import { Car } from "./car";export function drive(car: Car) { // ...}

TypeScript检测到您只对类型定义导入,就会完全删除导入。输出的JavaScript可能如下:

export function drive(car) { // ...}

如果 ./car 文件中仅仅定义了type 或者interface,转换为javascript时这些定义被抛弃,是正确。但是,如果 ./car中的Car是一个class,里边还包括了一些其他定义。这个文件被抛弃。最终的javascript可能会产生Runtime error。

importsNotUsedAsValues选项就解决了这个问题。

此标志控制导入的工作方式,有三种不同的选项:

remove:丢弃没有使用的import。【默认值】preserve:保留所有的import,即使从来没有使用过的定义。error:基本上和preserve选项一致,但是,当值(value)被import仅用作 type 时会报错。如果您希望确保没有意外导入任何值,此时可以使用此选项。

preserveValueImports作用:

TypeScript选项‘importsNotUsedAsValues‘和‘preserveValueImports‘弃用(typescriptlang)

例如:

import { Animal } from "./animal.js";eval("console.log(new Animal().isDangerous())");

这样的代码编译器不知道是否该保留还是该抛弃。如果想保留,请使用preserveValueImports选项

importsNotUsedAsValues、preserveValueImports还有一个isolatedModules共三个选项,比较难以理解,有时候使用时仍旧有一些边缘情况导致非期盼的结果。

从TypeScript5.0开始,引入了verbatimModuleSyntax选项(值为 true,false)。使用type修饰符,就明确保留还是抛弃,以简化以上情况。

任何不带类型修饰符的导入或者导出都会被保留。任何使用类型修饰符的内容都将被完全删除。// This statement can be dropped entirely in JS outputimport type * as car from "./car";// The named import/export 'Car' can be dropped in JS outputimport { type Car } from "./car";export { type Car } from "./car";// Erased away entirely.import type { A } from "a";// Rewritten to 'import { b } from "bcd";'import { b, type c, type d } from "bcd";// Rewritten to 'import {} from "xyz";'import { type xyz } from "xyz";

使用此选项后,实现了所见即所得。有type修饰符的,明确只使用了定义,编译时直接抛弃;没有使用type修饰符的,编译时就会保留其内容。

一般情况下,vscode会首先使用自带的TypeScript版本。最近升级后TypeScipt默认都会是5.X版本。

如果想继续使用5.x版本,增加一个选项: 在tsconfig.json 中增加 "ignoreDeprecations": "5.0",就不再报警了。

项目如果想切换到4.X版本:

切换TypeScript版本:首先确保在本项目已经有TypeScript4.x 如果没有可以 npm install typescript @4.9 然后

第一种方法:快捷键:Ctrl + Shift + P 然后输入 Typescript: Select Typescript Version,选择本项目的版本。 第二种方法:打开一个ts或者tsx文件。右下角有TypeScript JSX字样,在左边的{ }上,鼠标悬停,在弹窗中点击目前的TypeScript版本。然后会让选择新的TypeScript版本。

OK,切换成功。

本文链接地址:https://www.jiuchutong.com/zhishi/295348.html 转载请保留说明!

上一篇:使用axis调用WebService,Java WebService调用工具类(客户端调用axis1.4的方式)

下一篇:Chrome浏览器中清除特定网站的Cookie数据(chrome浏览器清除数据)

  • 进项税和销项税税率一样吗
  • 开出收据要做财务报表吗
  • 已收货款没发货怎么退款
  • 现金余额本月金额和本年累计金额怎么填
  • 出差补贴计入工资总额吗
  • 小企业汇算清缴所得税会计分录
  • 销售费用与管理的关系
  • 土地增值税可扣除的税金有哪些
  • 劳务派遣 税务
  • 季节性停用的设备应计提折旧吗
  • 低值易耗品计入什么账户
  • 企业计提长期借款的利息
  • 非货币性资产交换的会计处理
  • 企业借款不能超过资金多少
  • 进项税转出的附加税怎么做
  • 增值税普通发票可以抵扣进项税吗
  • 资产的税务处理要注意什么
  • 商标是按年交费的吗
  • 股权成本计算公式rd
  • 发生工伤事故先怎么办
  • 三证合一后未办理税务登记
  • 货币性项目和非货币性项目的区别是什么?如何进行处理?
  • 机动车销售发票如何认证抵扣?
  • 收到政府财政拨款用于购买生产设备
  • win11任务栏失灵
  • 租金收入缴纳个税
  • 怎么解决windows许可证即将过期
  • 没有桌面和任务栏怎么办
  • 进程aissca.exe
  • 支付代销手续费缴纳增值税吗
  • 固定资产核销程序
  • php wechat
  • 差旅费车票抵扣的相关规定
  • 第三方代收的款项是什么意思
  • php互换两个变量的关系
  • css教程网站
  • 置顶文章
  • 不交社保个税怎么处理
  • 所有者权益合计怎么算
  • 税控盘抵扣怎么做账
  • ps怎么移动某个图案
  • sql注入攻击代码
  • mysql日期和时间分开存的 索引
  • 房地产按揭贷款政策
  • 财政补贴收入要交增值税税率
  • 用友电子报表怎么生成
  • 营业税暂行实施细则
  • 加油站固定资产折旧方法
  • 住房公积金的账户状态是封存是什么意思
  • 以存货抵偿债务
  • 哪些行业不适用作业法
  • 小规模纳税人的认定标准是什么
  • 交易性金融资产公允价值变动计入
  • 固定资产改变用途折旧处理
  • 旅行社代订机票怎么做账
  • 公认会计原则是哪个国家的?
  • 查询存储过程中的文件
  • 微软6月24号
  • win7系统一键还原方法
  • centos 安装方法
  • 戴尔电脑u盘快速启动
  • win7系统连接VPN失败时提示错误代码721的故障分析及解决方法
  • spool.exe - spool是什么进程
  • pull current
  • linux的文件结构
  • pc是什么软件
  • win7断电后无法正常启动
  • win8找不到恢复环境怎么恢复出厂设置
  • mobile windows
  • linux网卡添加vlan
  • vim多行匹配
  • nodejs bff
  • 如何给图像应用css滤镜处理效果
  • python生成器有几种写法
  • vue实现下载功能
  • Unity uGui RawImage 渲染小地图
  • js使用类
  • 增值税纳税申报表附列资料(一)
  • 代理记账公司自查自纠情况报告范文
  • 宿豫区国税分局电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设