Как преобразовать TypeScript ES6 в ES5 с помощью Babel

#javascript #reactjs #typescript

Вопрос:

Я создаю библиотеку компонентов и хотел бы иметь возможность использовать это в других местах.

У меня есть следующий компонент в src/components/List/List.tsx

 import React from 'react'
import styled from '@mui/material/styles/styled'

import MuiList, { ListProps as MuiListProps } from '@mui/material/List'

const ListStyled = styled(MuiList)`
  text-decoration: none;
  cursor: pointer;
`

export const List: React.FC<MuiListProps> = ({ children, ...props }) => {
  return <ListStyled {...props}>{children}</ListStyled>
}

export default List
 

При запуске:

 rm -rf dist amp;amp; NODE_ENV=production babel src/components --out-dir dist --copy-files --ignore __tests__,__snapshots__,__mocks__,test.tsx,stories.js
 

Скомпилированная версия выглядит следующим образом dist/List/List.tsx :

 import React from 'react'
import styled from '@mui/material/styles/styled'

import MuiList, { ListProps as MuiListProps } from '@mui/material/List'

const ListStyled = styled(MuiList)`
  text-decoration: none;
  cursor: pointer;
`

export const List: React.FC<MuiListProps> = ({ children, ...props }) => {
  return <ListStyled {...props}>{children}</ListStyled>
}

export default List
 

Файл идентичен. Я хотел бы видеть dist/List/List.js идеал для использования моих пакетов. Но я понимаю, может быть, с TS это не может работать таким образом, Поскольку интерфейсы и т. Д. Больше Не Будут использоваться? Итак, логически я полагаю, что мне нужно dist/List/List.js будет сопровождать dist/List/List.d.ts ? Если да, то как я могу это сделать?

Ответ №1:

Проблема в том, что babel не распознает .tsx расширения файлов по умолчанию. --copy-files Флаг копирует файлы, которые не скомпилированы — именно поэтому в настоящее время копируется ваш файл.

Вы можете добавить флаг расширений с .tsx включенным --extensions '.tsx' , и он попытается их скомпилировать.

Я смог скомпилировать ваш файл с помощью babel src/components/List.tsx --out-dir dist --extensions '.tsx' --presets @babel/preset-typescript

Пример вывода:

 "use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.default = exports.List = void 0;

var _react = _interopRequireDefault(require("react"));

var _styled = _interopRequireDefault(require("@mui/material/styles/styled"));

var _List = _interopRequireDefault(require("@mui/material/List"));

var _excluded = ["children"];

var _templateObject;

function _interopRequireDefault(obj) { return obj amp;amp; obj.__esModule ? obj : { default: obj }; }

function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i  ) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }

function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i  ) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }

function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }

var ListStyled = (0, _styled.default)(_List.default)(_templateObject || (_templateObject = _taggedTemplateLiteral(["n  text-decoration: none;n  cursor: pointer;n"])));

var List = function List(_ref) {
  var children = _ref.children,
      props = _objectWithoutProperties(_ref, _excluded);

  return <ListStyled {...props}>{children}</ListStyled>;
};

exports.List = List;
var _default = List;
exports.default = _defau<
 

Комментарии:

1. Блестящее спасибо JDK. Вы случайно не знаете, как заставить определения typescript жаловаться вместе с этим? например: dist/List/List.d.ts

2. @JamieHutber это зависит от ваших настроек tsc / babel — см. typescriptlang.org/docs/handbook/babel-with-typescript.html

3. Еще один вопрос от меня. Кажется, что этот тип экспортируемого файла не может быть использован без предустановки babel: "@babel/preset-react" возможно ли экспортировать их и использовать без этого?

Ответ №2:

На самом деле, для создания библиотеки или пакета для вашего проекта вы должны использовать rollup наряду с реализацией typescript конфигураций.

Я испытал это и потерял много часов, чтобы настроить базовый, но полностью назначенный моим другом TSDX CLI с нулевой конфигурацией для разработки пакета TypeScript, который содержит:

  1. CJS
  2. ESM
  3. UMD
  4. Создание дерева
  5. Живая игровая площадка
  6. Сборки Dev / Prod
  7. Zero-config
  8. Шаблоны проектов
  9. TypeScript
  10. Накопительный
  11. Jest
  12. Красивее
  13. ESLint

Он создан Джаредом Палмером, этот пакет TSDX и CLI для создания того, что вы хотите, даже вы можете добавить свои дополнительные конфигурации. у него также есть полная документация и очень активное сообщество. Все конфигурации TypeScript, Babel, building полностью настроены в наилучшем оптимальном случае.

Вы можете создать новый пакет с помощью этой команды:

 npx tsdx create [your lib name]
 

А затем переместите свои коды в src папку, даже для типов экспорта не нужны никакие конфигурации, просто экспортируйте типы в корневой файл экспорта src папки, как показано ниже:

 // index.ts or index.tsx // the root index file in src folder
import type { OneComponentProps } from '../OneComponent';

export type { OneComponentProps };