Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@kokojs/babel-preset-h5

Package Overview
Dependencies
Maintainers
0
Versions
300
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@kokojs/babel-preset-h5

Babel preset for h5 projects.

  • 4.0.27
  • latest
  • npm
  • Socket score

Version published
Weekly downloads
113
decreased by-20.42%
Maintainers
0
Weekly downloads
 
Created
Source

Babel 预设配置 - H5

babel-preset-h5 是有赞 H5 应用统一的 Babel 配置。

使用方式

安装

yarn add @kokojs/babel-preset-h5 --dev

PS: 如果项目中安装了 @youzan/koko-preset-h5,默认就会依赖 @kokojs/babel-preset-h5,因此可以跳过安装。

配置

babel.config.js 中添加对应的 preset:

module.exports = {
  presets: ['@kokojs/babel-preset-h5'],
};

如果是 npm 包的话,还需要在 dependencies 里添加以下两个依赖:

{
  "dependencies": {
    "@babel/runtime": "7.x",
    "core-js": "3.x"
  }
}

配置项

useESModules

  • Type: boolean
  • Default: true

useESModules 用于控制编译后的模块是否为 ESModule,默认为true,如果需要编译到 commonjs 模块,可以将这项配置设置为false

module.exports = {
  presets: [
    [
      '@kokojs/babel-preset-h5',
      {
        useESModules: false,
      },
    ],
  ],
};

一般情况下,我们推荐默认输出 ESModule 模块,因为 ESModule 可以触发 Webpack 的 Tree Shaking 和 Scope Hoisting,从而减少代码体积.

如果你的 npm 包需要适配 Webpack 1.x 的旧仓库,则必须输出 commonjs 模块,因为 Webpack 1.x 不支持直接编译 ESModule.

当然,你也可以通过工具来同时输出两个版本,比如使用 rollup 的 output.format 来同时输出 ESModule 和 commonjs.

useBuiltIns

  • Type: string | boolean
  • Default: 'usage'
  • 可选值:'entry'false

等同于 @babel/preset-env 的 useBuiltIns 选项,用于控制 polyfill 的行为。

默认情况下,代码中会添加 core-js@3 的 polyfill 来确保兼容性。

在某些特殊场景下可以将这项配置设置为 false 来禁用 core-js(比如这个包需要在小程序中使用,而小程序不支持 core-js)。

注意:如果禁用了 core-js,请谨慎在代码中使用 ESNext API,以避免出现兼容性问题。

module.exports = {
  presets: [
    [
      '@kokojs/babel-preset-h5',
      {
        useBuiltIns: false,
      },
    ],
  ],
};

coreJsPure

  • Type: boolean
  • Default: false

coreJsPure 用于控制 core-js 的 polyfill 是否污染全局命名空间。

配置该属性后,编译结果的依赖将从 core-js 变更为 @babel/runtime-corejs3。

此选项的优先级高于 useBuiltIns 选项。

{
  "dependencies": {
    "@babel/runtime-corejs3": "7.x"
  }
}

loose

  • Type: boolean
  • Default: true

是否开启 babel-preset-envloose 模式。

module.exports = {
  presets: [['@kokojs/babel-preset-h5', { loose: false }]],
};

excludeStyleLibs

  • Type: string[]
  • Default: []

excludeStyleLibs 用于控制打包时需要排除的组件库样式文件,通过配置这个属性,可以在将组件处理为 externals 依赖时,不打包对应的样式文件

enableDevTranspile

  • Type: boolean
  • Default: false

是否在 dev 模式下将代码编译至 ES5,注意开启后会降低 dev 的编译速度。

默认情况下,我们会在 build 时将代码编译至 ES5,而在 dev 阶段仅会对代码进行最小程度的编译(仅保证最新浏览器能运行)。

targets

  • Type: string | string[] | object
  • Default: ['Android >= 4.0', 'iOS >= 8']

编译目标浏览器版本,等同于 @babel/preset-env 的 targets 选项

optimizeConstEnums

  • Type: boolean
  • Default: false

传递给 @babel/preset-typescript 的参数,是否开启 const enum 编译优化。

module.exports = {
  presets: [
    [
      '@kokojs/babel-preset-h5',
      {
        optimizeConstEnums: true,
      },
    ],
  ],
};

内置插件列表

@babel/preset-env

用于 polyfill ESNext 语法和添加 core-js3

@babel/plugin-transform-runtime

用于将 Babel helper 转换为 import 形式,减少代码体积

@babel/preset-typescript

用于转换 TypeScript 语法

babel-plugin-import

用于组件库按需引入,目前包含以下组件库:

  • vant
  • @youzan/vis-ui
  • @youzan/captain
  • @youzan/brand-ui
  • @youzan/captain-showcase
  • @youzan/wsc-membercenter
  • @youzan/pay-components-h5

注意:此配置中不包含旧版 captain-ui,如果项目中依然使用了旧版 captain-ui,请保留对 captain-ui 的按需引入配置

@babel/plugin-proposal-class-properties

用于转换 class 的属性

@vue/babel-preset-jsx

用于转换 Vue JSX 语法,详见 vuejs/jsx

@babel/plugin-proposal-decorators

装饰器语法支持,可用于结合 vue-property-decorator 来使用 TS 编写 Vue 文件

维护者

陈嘉涵。

FAQs

Package last updated on 18 Dec 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc