Das Erstellen einer modernen React-Bibliothek erfordert eine sorgfältige Berücksichtigung von Build-Tools, Entwicklungserfahrung und Ausgabeoptimierung. Dieser Leitfaden führt Sie durch den Aufbau eines professionellen React-Bibliotheksstarters mit TypeScript, SWC und Rollup – einer leistungsstarken Kombination, die überragende Leistung, Zuverlässigkeit und Entwicklererfahrung bietet.
Statische Typprüfung: Fehler während der Entwicklung und nicht zur Laufzeit erkennen
Erweiterte IDE-Unterstützung: Bessere automatische Vervollständigung, Refactoring und Code-Navigation
Selbstdokumentierender Code: Typen dienen als lebendige Dokumentation
Verbesserte Wartung: Macht große Codebasen einfacher zu verwalten
Wachsende Community: Umfangreiche Typdefinitionen für beliebte Bibliotheken
mkdir react-library cd react-library npm init -y # Create essential directories mkdir src
# Core dependencies npm install react react-dom --save-peer # Development dependencies npm install --save-dev typescript @types/react @types/react-dom \ @swc/core @swc/helpers \ rollup @rollup/plugin-swc @rollup/plugin-node-resolve \ @rollup/plugin-commonjs rollup-plugin-peer-deps-external
Tsconfig.json erstellen:
{ "compilerOptions": { "target": "ES2018", "module": "ESNext", "lib": ["DOM", "DOM.Iterable", "ESNext"], "declaration": true, "declarationDir": "dist/types", "emitDeclarationOnly": true, "jsx": "react-jsx", "strict": true, "moduleResolution": "node", "allowSyntheticDefaultImports": true, "esModuleInterop": true, "skipLibCheck": true, "forceConsistentCasingInFileNames": true, "resolveJsonModule": true, "isolatedModules": true, "noUnusedLocals": true, "noUnusedParameters": true, "noImplicitReturns": true, "noFallthroughCasesInSwitch": true }, "include": ["src"], "exclude": ["node_modules", "dist"] }
Rollup.config.js erstellen:
import resolve from '@rollup/plugin-node-resolve'; import commonjs from '@rollup/plugin-commonjs'; import { swc, defineRollupSwcOption } from '@rollup/plugin-swc'; import peerDepsExternal from 'rollup-plugin-peer-deps-external'; import terser from '@rollup/plugin-terser'; const packageJson = require('./package.json'); const swcConfig = defineRollupSwcOption({ jsc: { parser: { syntax: 'typescript', tsx: true, }, transform: { react: { runtime: 'automatic', development: false, refresh: false, }, }, target: 'es2018', }, minify: false, }); export default [ // ESM build { input: 'src/index.tsx', output: [ { file: packageJson.module, format: 'esm', sourcemap: true, }, ], plugins: [ peerDepsExternal(), resolve({ extensions: ['.ts', '.tsx', '.js', '.jsx'], }), commonjs(), swc(swcConfig), terser(), ], external: ['react', 'react-dom'], }, // CommonJS build { input: 'src/index.tsx', output: [ { file: packageJson.main, format: 'cjs', sourcemap: true, exports: 'auto', }, ], plugins: [ peerDepsExternal(), resolve({ extensions: ['.ts', '.tsx', '.js', '.jsx'], }), commonjs(), swc(swcConfig), terser(), ], external: ['react', 'react-dom'], }, ];
Aktualisieren Sie Ihre package.json:
{ "name": "your-library-name", "version": "1.0.0", "main": "dist/cjs/index.js", "module": "dist/esm/index.js", "types": "dist/types/index.d.ts", "files": [ "dist" ], "sideEffects": false, "scripts": { "build": "rollup -c", "types": "tsc", "prepare": "npm run types && npm run build", "lint": "eslint ." }, "peerDependencies": { "react": ">=17.0.0 <19.0.0", "react-dom": ">=17.0.0 <19.0.0" }, }
Src/index.tsx erstellen:
mkdir react-library cd react-library npm init -y # Create essential directories mkdir src
Richten Sie eine Vite-App ein, um Beispiele bereitzustellen und Codeänderungen im Repo selbst zu testen. Dies geht auch mit einem Bilderbuch.
# Core dependencies npm install react react-dom --save-peer # Development dependencies npm install --save-dev typescript @types/react @types/react-dom \ @swc/core @swc/helpers \ rollup @rollup/plugin-swc @rollup/plugin-node-resolve \ @rollup/plugin-commonjs rollup-plugin-peer-deps-external
Fügen Sie Ihr Paket im Abschnitt „Abhängigkeiten“ der Beispieldatei package.json hinzu
{ "compilerOptions": { "target": "ES2018", "module": "ESNext", "lib": ["DOM", "DOM.Iterable", "ESNext"], "declaration": true, "declarationDir": "dist/types", "emitDeclarationOnly": true, "jsx": "react-jsx", "strict": true, "moduleResolution": "node", "allowSyntheticDefaultImports": true, "esModuleInterop": true, "skipLibCheck": true, "forceConsistentCasingInFileNames": true, "resolveJsonModule": true, "isolatedModules": true, "noUnusedLocals": true, "noUnusedParameters": true, "noImplicitReturns": true, "noFallthroughCasesInSwitch": true }, "include": ["src"], "exclude": ["node_modules", "dist"] }
Importieren Sie Ihre Komponente und testen Sie sie im Beispielprojekt.
Ihre React-Bibliothek ist jetzt zur Veröffentlichung bereit! ?
Wenn Sie mit einem gebrauchsfertigen Setup loslegen möchten, sehen Sie sich die vollständige Starter-Vorlage hier an: https://github.com/Abhirup-99/react-library-starter-template. Diese Vorlage enthält alles, was wir behandelt haben, und soll Ihnen dabei helfen, die Entwicklung Ihrer React-Bibliothek mit minimalem Setup zu starten.
Viel Spaß beim Codieren!
Das obige ist der detaillierte Inhalt vonAufbau eines modernen React-Bibliotheksstarters: Ein umfassender Leitfaden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!