npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

exp-defaults

v1.0.48

Published

将一个js文件的所有导出统一在一个文件下使用默认导出的方式分别导出

Downloads

58

Readme

说明

将一个 js 文件中所有导出组件,在另一个文件夹中统一使用默认导出的方式分别独立导出。

安装方法

npm i exp-defaults

使用方法

exp-defaults [targetDir] [rootDir] [mainExportFile]

传参说明

| 参数 | 说明 | 必填 | 默认 | | -------------- | -------------------------------------------- | ---- | -------- | | rootDir | 根目录 | 否 | "./src/" | | targetDir | 统一默认导出組件的目标文件夹(相对于 rootDir) | 否 | "/libs" | | mainExportFile | 含导出组件信息的文件路径 | 否 | index.js |

使用场景

经常我们写一个组件库,开始考虑不周在组件库中通常会 export {Component1, Component2, Component3...}导出所有组件,但是当我们需要按需引入优化、懒加载等场景时,又需要将各组件以默认导出的方式剥离出来,这时要么手动重新依次写导出文件,要么就需要修改原来组件的导出形式。 exp-defaults 工具将自动读取指定 js 文件中所有导出组件信息,在另一个文件夹中统一使用默认导出的方式分别独立导出。

如有以下文件结构:

project-name/
│
├── src/
│  ├── index.js
│  └── components/
│    ├── Component1/
│    ├── Component2/
│    ├── Component3/
│    └── ......
└── ......

其中,src/index.js 中导出组件:

import Component1 from './components/Component1'
import { Component2, Component3 } from './components/Component1'
export { Component1, Component2, Component3 }

如使用本工具:

exp-defaults libs ./src index.js

则,在./src 下生成 libs 文件夹,并自动生成所有的导出组件文件:

project-name/
│
├── src/
│  ├── index.js
│  └── components/
│    ├── Component1/
│    ├── Component2/
│    ├── Component3/
│    └── ......
│──── libs/
│    ├── Component1/
│    │  └── index.js
│    ├── Component2/
│    │  └── index.js
│    ├── Component3/
│    │  └── index.js
│    └── ......
└── ......

其中,src/libs/Component1/index.js 中导出组件:

import Component1 from '../../components/Component1'
export default Component1

其中,src/libs/Component2/index.js 中导出组件:

import { Component2 } from '../../components/Component2'
export default Component2

其中,src/libs/Component3/index.js 中导出组件:

import { Component3 } from '../../components/Component3'
export default Component3

至此可以直接使用/src/libs 文件夹中的组件

在构建工具中按需引用时,可以使用以下配置,以 rspack 为例,webpack 配置也差不多:


......

const files = fs.readdirSync(path.resolve(__dirname, '/src/libs/'))
let entry = {}
for (const item of files) {
    entry[item] = path.resolve(__dirname, `/src/libs/${item}/`, 'index.js')
}

module.exports = {
    mode: 'production',
    entry,
    output: {
        clean: true,
        path: path.resolve(__dirname, './', 'lib'),
        filename: '[name]/index.js',
        library: {
            name: 'Component_Library_Name',
            type: 'umd',
            export: 'default',
            umdNamedDefine: true,
        },
    },
    ......
}