vite+ts配置之项目别名以及后缀省略

背景

懒,为了少些几个字母

对比

未配置别名

我们在src/views/demo/index.vue文件下面想引入src/components/gd-upload组件,我们需要下面这种方式

html 复制代码
<template>
  <div>
    <GdUpload />
  </div>
</template>

<script setup lang="ts">
  import GdUpload from '../../components/gd-upload';
</script>

<style scoped></style>
配置了别名
html 复制代码
<template>
  <div>
    <GdUpload />
  </div>
</template>

<script setup lang="ts">
  import GdUpload from '@com/gd-upload';
</script>

<style scoped></style>

我们可以发现,配置了别名之后,我们从import GdUpload from '../../components/gd-upload'变成了import GdUpload from '@com/gd-upload'

好处:
  • 代码写的少
  • 不管嵌套多少级文件夹,我们引入文件的位置都很清晰

开始配置

vite.config.ts
ts 复制代码
export default defineConfig({
	... 其他配置
	resolve: {
		// 导入时想要省略的扩展名列表。注意,不 建议忽略自定义导入类型的扩展名(例如:.vue),因为它会影响 IDE 和类型支持。
	    extensions: ['.js', '.ts', '.json', '.tsx'],
	    // 别名配置 一般常用@ ~ 这些符号去配置,不过也不强求,看自己喜好
	    alias: {
	      '@': path.resolve(__dirname, './src'),
	      // 这个配置不配置都可以,看自己的需求
	      '@com': path.resolve(__dirname, './src/components'),
	    },
	},
	... 其他配置
})
tsconfig.app.json或者tsconfig.json

因为我的tsconfig配置是分了多个文件,所以我就在tsconfig.app.json中配置了

  • baseUrl
  • paths
json 复制代码
 "compilerOptions": {
    "composite": true,
    // 增加了浏览器特有的dom相关api
    "lib": ["ESNext", "DOM", "DOM.Iterable"],
    "types": ["node"],
    "jsx": "preserve",
    "jsxImportSource": "vue",
    // 主要是baseUrl以及path这两个属性
    "baseUrl": "./",
    "paths": {
      "@/*": ["src/*"],
      "@com/*": ["src/components/*"]
    }
  },
相关推荐
冰暮流星12 小时前
css之线性渐变
前端·css
徐同保12 小时前
tailwindcss暗色主题切换
开发语言·前端·javascript
mapbar_front12 小时前
大厂精英为何在中小公司水土不服?
前端
生莫甲鲁浪戴13 小时前
Android Studio新手开发第二十七天
前端·javascript·android studio
2501_9160088915 小时前
Web 前端开发常用工具推荐与团队实践分享
android·前端·ios·小程序·uni-app·iphone·webview
SkylerHu16 小时前
前端代码规范:husky+ lint-staged+pre-commit
前端·代码规范
菜鸟una16 小时前
【微信小程序 + 消息订阅 + 授权】 微信小程序实现消息订阅流程介绍,代码示例(仅前端)
前端·vue.js·微信小程序·小程序·typescript·taro·1024程序员节
Yeats_Liao16 小时前
Go Web 编程快速入门 05 - 表单处理:urlencoded 与 multipart
前端·golang·iphone
飞翔的佩奇16 小时前
【完整源码+数据集+部署教程】【运动的&足球】足球场地区域图像分割系统源码&数据集全套:改进yolo11-RFAConv
前端·python·yolo·计算机视觉·数据集·yolo11·足球场地区域图像分割系统
拉不动的猪16 小时前
h5后台切换检测利用visibilitychange的缺点分析
前端·javascript·面试