import-js/eslint-plugin-import

Ensure packages are imported the same way (`import "react"` vs `import("react")`)

Open

#2,326 创建于 2021年12月12日

在 GitHub 查看
 (21 评论) (0 反应) (0 负责人)JavaScript (4,946 star) (1,540 fork)batch import
help wantedrule proposal

描述

import() is used as an indicator that the bundler can create an additional file (code splitting) instead of including the specified dependency in the main bundle.

Unfortunately it's possible that the same dependency is imported statically in another file, therefore either cancelling the effect or perhaps bundling it twice.

// index
import './a.js'
import './b.js'
// a.js
import { React } from 'react';
// b.js
const { React } = await import('react');

Rule request

Is it possible to ensure that a specific dependency is imported the same way across files automatically?

"import/consistent-import-style": "error"

If not automatically, I wish there was a way to enforce a certain import method per-dependency, for example:

"import/enforce-import-style": [
	"error",
	{
		static: ["react"],
		dynamic: ["my-little-heavy-dep"],
	}
]

贡献者指南