unplugin-auto-import

Auto import APIs on-demand for Vite, Webpack, Rollup and esbuild. With TypeScript support. Powered by unplugin.
without
import { computed, ref } from 'vue'
const count = ref(0)
const doubled = computed(() => count.value * 2)
with
const count = ref(0)
const doubled = computed(() => count.value * 2)
without
import { useState } from 'react'
export function Counter() {
const [count, setCount] = useState(0)
return <div>{ count }</div>
}
with
export function Counter() {
const [count, setCount] = useState(0)
return <div>{ count }</div>
}
Install
npm i -D unplugin-auto-import
Vite
import AutoImport from 'unplugin-auto-import/vite'
export default defineConfig({
plugins: [
AutoImport({ }),
],
})
Example: playground/
Rollup
import AutoImport from 'unplugin-auto-import/rollup'
export default {
plugins: [
AutoImport({ }),
],
}
Webpack
module.exports = {
plugins: [
require('unplugin-auto-import/webpack')({ }),
],
}
Nuxt
You don't need this plugin for Nuxt, it's already builtin.
Vue CLI
module.exports = {
configureWebpack: {
plugins: [
require('unplugin-auto-import/webpack')({ }),
],
},
}
Quasar
module.exports = {
vitePlugins: [
['unplugin-auto-import/vite', { }],
],
}
const AutoImportPlugin = require('unplugin-auto-import/webpack')
module.exports = {
build: {
chainWebpack(chain) {
chain.plugin('unplugin-auto-import').use(
AutoImportPlugin({ }),
)
},
},
}
esbuild
import { build } from 'esbuild'
build({
plugins: [
require('unplugin-auto-import/esbuild')({
}),
],
})
Astro
import AutoImport from 'unplugin-auto-import/astro'
export default defineConfig({
integrations: [
AutoImport({
})
],
})
Configuration
AutoImport({
include: [
/\.[tj]sx?$/,
/\.vue$/, /\.vue\?vue/,
/\.md$/,
],
imports: [
'vue',
'vue-router',
{
'@vueuse/core': [
'useMouse',
['useFetch', 'useMyFetch'],
],
'axios': [
['default', 'axios'],
],
'[package-name]': [
'[import-names]',
['[from]', '[alias]'],
],
},
],
defaultExportByFilename: false,
dirs: [
],
dts: './auto-imports.d.ts',
vueTemplate: false,
resolvers: [
],
eslintrc: {
enabled: false,
filepath: './.eslintrc-auto-import.json',
globalsPropValue: true,
},
})
Refer to the type definitions for more options.
Presets
See src/presets.
TypeScript
In order to properly hint types for auto-imported APIs
- Enable
options.dts so that auto-imports.d.ts file is automatically generated
- Make sure
auto-imports.d.ts is not excluded in tsconfig.json
|
AutoImport({
dts: true
})
|
ESLint
💡 When using TypeScript, we recommend to disable no-undef rule directly as TypeScript already check for them and you don't need to worry about this.
If you have encountered ESLint error of no-undef:
|
|
AutoImport({
eslintrc: {
enabled: true,
},
})
|
|
|
module.exports = {
extends: [
'./.eslintrc-auto-import.json',
],
}
|
FAQ
From v0.8.0, unplugin-auto-import uses unimport underneath. unimport is designed to be a lower level tool (it also powered Nuxt's auto import). You can think unplugin-auto-import is a wrapper of it that provides more user-friendly config APIs and capability like resolvers. Development of new features will mostly happend in unimport from now.
You can think of this plugin as a successor to vue-global-api, but offering much more flexibility and bindings with libraries other than Vue (e.g. React).
Pros
- Flexible and customizable
- Tree-shakable (on-demand transforming)
- No global population
Cons
- Relying on build tools integrations (while
vue-global-api is pure runtime) - but hey, we have supported quite a few of them already!
License
MIT License © 2021 Anthony Fu