Skip to content

Latest commit

 

History

History
91 lines (63 loc) · 2.39 KB

README.zh-CN.md

File metadata and controls

91 lines (63 loc) · 2.39 KB

babel-plugin-jsx-asset-url-import

提取 JSX 中的静态资源路径并转换为 import

English | 简体中文

npm GitHub Workflow Status Codecov

示例

Input

import React from 'react';

const App: React.FC = () => {
  return <img src="./logo.png" alt="" />
}

Output

import React from 'react';
import _import_assets from './logo.png';

const App: React.FC = () => {
  return <img src={_import_assets} alt="" />
}

安装与使用

pnpm add -D babel-plugin-jsx-asset-url-import

babel.config.js

export default {
  plugins: ['jsx-asset-url-import'],
};

选项

includeAbsolute

  • 类型: boolean
  • 默认值: false

提取时包含绝对路径

tags

  • 类型: Record<string, string[]>

  • 默认值:

    {
      audio: ['src'],
      embed: ['src'],
      img: ['src', 'srcSet'],
      input: ['src'],
      object: ['data'],
      source: ['src', 'srcSet'],
      track: ['src'],
      video: ['poster', 'src'],
      image: ['xlinkHref', 'href'],
      use: ['xlinkHref', 'href'],
    }

配置需要提取和转换的标签及属性, 如果你想提取自定义组件的属性, 请在这里添加. 插件内部将与默认配置合并

如果你的组件包含在一个对象中, 类似于 <Foo.Bar src="./logo.png" /> , 你需要配置为: 'Foo.Bar': ['src']

如果你想要禁用默认配置中的规则, 你需要配置为: img: []

参考与感谢