自动导入插件unplugin-auto-import/unplugin-vue-components

原文地址: devpress.csdn.net/vue/66cd509...

1. unplugin-auto-import(自动导入API)

安装: npm i -D unplugin-auto-import

配置:

ts 复制代码
// vite.config.ts
import AutoImport from 'unplugin-auto-import/vite'

export default defineConfig({
  plugins: [
    AutoImport({ /* options */ }),
  ],
})

options详细配置:

配置解析

  1. dirs: 目录下模块导出的自动导入。默认情况下,它只扫描目录下的一级模块,我们可以添加一些通配符来做筛选,限定到指定目录,或者到src 都可以做到自动引入,但是为了精确化查找,建议匹配越精准越好
ts 复制代码
 // 配置本地目录 自动引入
  dirs: ['./src/utils/**', './src/stores/**'],
 //dirs: ['./src/**'],
  1. dts: 生成相应.d.ts文件的文件路径。默认为""/在本地安装"typescript"时自动导入.d.ts。
ts 复制代码
 dts: './auto-imports.d.ts',
  1. imports: 需要全局引入的

示例

without

ts 复制代码
import { computed, ref } from 'vue'

const count = ref(0)
const doubled = computed(() => count.value * 2)

with

ts 复制代码
const count = ref(0)
const doubled = computed(() => count.value * 2)

without

ts 复制代码
import {f1} from '@/utils'
f1();

with

ts 复制代码
f1();

without

ts 复制代码
import {concat} from 'lodash';
console.log(concat([1, 2], [3]))

with

ts 复制代码
console.log(concat([1, 2], [3]))

without

ts 复制代码
import { useState } from 'react'

export function Counter() {
  const [count, setCount] = useState(0)
  return <div>{ count }</div>
}

with

ts 复制代码
export function Counter() {
  const [count, setCount] = useState(0)
  return <div>{ count }</div>
}

2. unplugin-vue-components( 自动导入组件)

安装

ts 复制代码
npm i -D unplugin-vue-components

配置

这里我测试了一下,就算什么也不写,Components默认会自动引入 /src/components下的文件

ts 复制代码
// vite.config.ts
import Components from 'unplugin-vue-components/vite'

export default defineConfig({
  plugins: [
    Components({ /* options */ }),
  ],
})

你也可以再配置一些想自动引入的组件

dirs: ['./src/components', './src/index/components'],

如果害怕组件重名,可以加一个directoryAsNamespace的选项,这样自动导入的组件名称 包含目录 ,就会防止命名冲突

options 里面可以添加一些配置

  • 三方组件,也可以在这里进行自动引入
ts 复制代码
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers';
 
Components({
  // vue-components 内置了前端主流的resolve element antd
  resolvers: [ElementPlusResolver()],
  dirs: ['src/components'],
  // 组件名称 包含目录 ,防止命名冲突
  directoryAsNamespace: true,
}),

示例

without

相关推荐
YCOSA20251 小时前
ISO 雨晨 26200.6588 Windows 11 企业版 LTSC 25H2 自用 edge 140.0.3485.81
前端·windows·edge
小白呀白1 小时前
【uni-app】树形结构数据选择框
前端·javascript·uni-app
吃饺子不吃馅2 小时前
深感一事无成,还是踏踏实实做点东西吧
前端·svg·图形学
90后的晨仔2 小时前
Mac 上配置多个 Gitee 账号的完整教程
前端·后端
少年阿闯~~3 小时前
CSS——实现盒子在页面居中
前端·css·html
开发者小天3 小时前
uniapp中封装底部跳转方法
前端·javascript·uni-app
阿波罗尼亚3 小时前
复杂查询:直接查询/子查询/视图/CTE
java·前端·数据库
正义的大古3 小时前
OpenLayers地图交互 -- 章节九:拖拽框交互详解
前端·vue.js·openlayers
三十_A4 小时前
【实录】使用 Verdaccio 从零搭建私有 npm 仓库(含完整步骤及避坑指南)
前端·npm·node.js
huangql5204 小时前
从零到一打造前端内存监控 SDK,并发布到 npm ——基于 TypeScript + Vite + ECharts的解决方案
前端·typescript·echarts