@babel/plugin-transform-flow-strip-types

transform-flow-strip-types - 图1info

This plugin is included in @babel/preset-flow

Example

In

JavaScript

  1. function foo(one: any, two: number, three?): string {}

Out

JavaScript

  1. function foo(one, two, three) {}

Installation

  • npm
  • Yarn
  • pnpm
  1. npm install --save-dev @babel/plugin-transform-flow-strip-types
  1. yarn add --dev @babel/plugin-transform-flow-strip-types
  1. pnpm add --save-dev @babel/plugin-transform-flow-strip-types

Usage

babel.config.json

  1. {
  2. "plugins": ["@babel/plugin-transform-flow-strip-types"]
  3. }

Via CLI

Shell

  1. babel --plugins @babel/plugin-transform-flow-strip-types script.js

Via Node API

JavaScript

  1. require("@babel/core").transformSync("code", {
  2. plugins: ["@babel/plugin-transform-flow-strip-types"],
  3. });

Options

all

boolean, defaults to false.

Flow will only parse Flow-specific features if a @flow pragma is present atop the file, or the all option is set inside the .flowconfig.

If you are using the all option in your Flow config, be sure to set this option to true to get matching behavior.

For example, without either of the above, the following call expression with a type argument:

  1. f<T>(e)

Would get parsed as a nested binary expression:

JavaScript

  1. f < T > e;

requireDirective

boolean, defaults to false.

Setting this to true will only strip annotations and declarations from files that contain the // @flow directive. It will also throw errors for any Flow annotations found in files without the directive.

allowDeclareFields

boolean, defaults to false

Added in: v7.9.0

transform-flow-strip-types - 图2note

This will be enabled by default in Babel 8

When enabled, type-only class fields are only removed if they are prefixed with the declare modifier:

JavaScript

  1. class A {
  2. declare foo: string; // Removed
  3. bar: string; // Initialized to undefined
  4. }

transform-flow-strip-types - 图3tip

You can read more about configuring plugin options here