#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, который содержит:
- CJS
- ESM
- UMD
- Создание дерева
- Живая игровая площадка
- Сборки Dev / Prod
- Zero-config
- Шаблоны проектов
- TypeScript
- Накопительный
- Jest
- Красивее
- 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 };