当前位置: 首页 > news >正文

【Vite】控制打包结构

配置 vite.config.json 文件:

import { defineConfig } from "vite";export default defineConfig({// ...build: {rollupOptions: {output: {entryFileNames: "js/[name]-[hash].js",chunkFileNames: "js/[name]-[hash].js",assetFileNames(chunkInfo) {// CSS 文件if (chunkInfo.name?.endsWith(".css")) {return "css/[name]-[hash][extname]";}// 字体文件if ([".woff", ".woff2", ".ttf", ".eot"].some((ext) =>chunkInfo.name?.endsWith(ext))) {return "font/[name]-[hash][extname]";}// 图片文件if ([".png", ".jpg", ".jpeg", ".gif", ".svg", ".webp"].some((ext) => chunkInfo.name?.endsWith(ext))) {return "imgs/[name]-[hash][extname]";}// 其他文件return "assets/[name]-[hash][extname]";},},},},
});

如果为 Vite + TS 项目,此时 vite.config.json 文件会在 endsWith 处抛出错误:Property ‘endsWith’ does not exist on type ‘string’. Do you need to change your target library? Try changing the ‘lib’ compiler option to ‘es2015’ or later.

打开 tsconfig.json 一看 target,是 "ES2020" 昂!奇了怪了…

仔细看看 tsconfig.json 文件,欸~ tsconfig.json 文件的最下面有一行配置:

    "references": [{ "path": "./tsconfig.node.json" }]

到 tsconfig.node.json 一看,没有配置 target,默认为 "ES3"!再看一眼 include,为 ["vite.config.ts"]!回到 tsconfig.json 看一眼 include,为 ["src/**/*.ts", "src/**/*.tsx", "src/**/*.vue"]

噢~ 我好像懂了!tsconfig.json 为业务文件的 TS 配置文件,tsconfig.node.json 为 vite.config.ts 的 TS 配置文件!

于是我在 tsconfig.node.json 中配置 target"ES2020"

{"compilerOptions": {// 其他配置项"target": "ES2020" // 添加这一行},"include": ["vite.config.ts"]
}

OK!没有报错了~


http://www.lryc.cn/news/380874.html

相关文章:

  • Debian Linux安装minikubekubectl
  • Discuz动漫二次元风格网站模板
  • RIP、OSPF、IS-IS学习
  • 移植案例与原理 - build lite源码分析 之 hb命令__main__.py
  • Leo赠书活动-26期 不同数据库背后的数据存储方案
  • 在Windows10中使用Vim
  • 【Python机器学习实战】 | 基于PCA主成分分析技术读入空气质量监测数据进行数据预处理并计算空气质量综合评测结果
  • 学习java第一百零八天
  • Linux通配符总结
  • ffmpeg的安装教程
  • 禅道身份认证绕过漏洞(QVD-2024-15263)复现
  • 深入分析 Android BroadcastReceiver (六)
  • mysql 查询的一般思路
  • 【Web APIs】DOM 文档对象模型 ⑤ ( 获取特殊元素 | 获取 html 元素 | 获取 body 元素 )
  • Android11 以Window的视角来看FallbackHome的启动
  • 9 RestClient客户端操作文档
  • 『Z-Weekly Feed 08』加密资产观 | FHE应用前景 | OPAL协议
  • 酒店预定系统
  • Redis的实战常用一、验证码登录(解决session共享问题)(思路、意识)
  • 基于Spring Boot的智能分析平台
  • HTML(13)——显示模式
  • 【Spring】Spring Boot 快速入门
  • Go自定义数据的序列化流程
  • 贪心算法练习题(2024/6/18)
  • 4.1 四个子空间的正交性
  • RabbitMQ实践——使用WebFlux响应式方式实时返回队列中消息
  • SpringBoot前后端传递数据时常用的JSON格式数据是什么?【讲解JSON概念、语法、以及Java对象互转】
  • mysql学习——SQL中的DQL和DCL
  • windows系统上nginx搭建文件共享
  • 星闪指向遥控,做家电交互的破壁人