title | tags | created | modified | ||
---|---|---|---|---|---|
cli-frontend |
|
2020-06-19T04:40:23.543Z |
2020-07-14T10:35:06.446Z |
- storybook
- UI component dev & test: React, Vue, Angular, Web Components & more
- addon
- Knobs: edit props dynamically using the Storybook UI
- codesandbox
- Online Code Editor Tailored for Web Application
- eslint/tslint
- jest
- enzyme
- webpack
- entry
- output
- module
- loader
- resolve:设置模块如何被解析
- alias选项设置别名
- extensions指定解析器接受的扩展名
- npm
- 前端包管理器
- 常用命令
npm config list
:查看npm配置信息npm ls -g --depth=0
:查看本地全局安装的包npm i -D webpack --registry=https://registry.npm.taobao.org
- npm vs yarn
- npm包名规范
- 把包名中的标点符号去掉并与现有的包进行比较,相同则不允许发布
- 找到一个独一无二包名最简单方法就是使用作用域
@+用户名
,被划了作用域的包默认是私有的,所以要通过--access=public
让它变为公有的包
- yarn
- a package manager for your code
- Running
yarn
with no command will runyarn install
- workspaces
- 提升依赖下载到根目录,减少重复下载
- Nested workspaces are not supported at this time.
- yarn vs lerna
- lerna管理构建时的相互依赖和发布,yarn专注于依赖下载
- Yarn’s workspaces are the low-level primitives that tools like Lerna can (and do!) use.
- They will never try to support the high-level feature that Lerna offers, but by implementing the core logic of the resolution and linking steps inside Yarn itself we hope to enable new usages and improve performance.
- lerna
- A tool for managing JavaScript projects with multiple packages
- 多个package是放在单个仓库里维护还是放在多个仓库里单独维护
- monorepo:方便相互依赖的项目自动测试,但repo体积较大
- 多仓库维护:方便多人协作
- 多仓库包管理常见问题
- package之间相互依赖,开发人员需要在本地手动执行npm link,维护版本号的更替
- 每一个package都包含独立的node_modules,而且大部分都包含babel等开发时依赖,安装耗时冗余并且占用过多空间
- 多个包管理方案
- lerna
- yarn workspace
- npm link
- lerna使用体验
- 构建时自动解决packages之间的依赖关系,直接依赖本地项目源码
- 根据git提交记录,自动生成changelog
- 发布时一起发布多个包
- 统一管理依赖版本
- 包管理常用命令
lerna init
:以所有子包共用版本号的固定模式初始化项目, --independentlerna bootstrap
:为所有项目安装依赖,类似于npm i/yarnlerna add pkgA --scope=pkgB
:将A安装到B的字段, --dev,一次只能一包lerna publish
:先确定哪些包需要publish,--skip-git/npm- 先设置version,先打tag,再push到github,再上传npm,可通过参数拆分流程
lerna publish from-package --yes --registry http://
- 参考 lerna/lerna#1648
lerna ls
:显示packages下的各个package的versionnpm link
:可添加本地正在开发的包作为依赖
- git
- 常用命令
git branch branchName
: 创建新分支git checkout branchName startPoint
:切换到新分支git checkout -b bName
=g branch bName
+g checkout bName
git merge b
:将b分支合并到当前分支- 执行merge之后,会产生一个新的commit
git merge master feature
:将master分支合并到feature分支
git rebase
:功能和git merge
类似,git checkout feature
+git rebase master
- 将整个feature分支移动到master分支的后面,将master分支上新的提交并过来
- 不会产生新commit
- Conventional Commits
- add human and machine readable meaning to commit messages
- https://www.conventionalcommits.org
- fix, feat, chore, docs, style, refactor, perf, test
- date-fns
- 方便在浏览器和Node中操作时间日期
- provides the most comprehensive, yet simple and consistent toolset for manipulating JavaScript dates in a browser & Node.js
- react-markdown
- Renders Markdown as pure React components
- marked
- A markdown parser built for speed
- raf
- requestAnimationFrame polyfill for node and the browser
- fast-memoize
- fastest memoization library in js that supports N arguments
- memoization is an optimization technique used primarily to speed up computer programs by storing the results of expensive function calls and returning the cached result when the same inputs occur again
- memoize-one
- Unlike other memoization libraries, memoize-one only remembers the latest arguments and result
- memoize-one simply remembers the last arguments, and if the function is next called with the same arguments then it returns the previous result
- classnames
- js utility for conditionally joining classNames together
- immutable-js
- v4
- The Iterable class has been renamed to Collection
- improve Record impl, Record is no longer an Immutable Collection type
- Flowtype and TypeScript type definitions have been completely rewritten
- v4
- 对于typescript + monorepo的hot reload热加载
- 基本思路是将package.json的main属性值直接配置到源码如
src/index.tsx
,参考例子react-workspaces-playground - 对于某些特别复杂的项目,如ag-grid,由于使用的ts特性特别多,样式引用scss,编译需要的插件可能变得很复杂,热加载很可能编译不通
- 可以先采取过渡方案,将main属性值配置到
dist/index.js
,然后tsc --watch
编译依赖项目,这样修改时会自动编译出新的dist/index.js - 等到对项目源码思路熟练掌握时,可自定义重新构建
- 可以先采取过渡方案,将main属性值配置到
- 基本思路是将package.json的main属性值直接配置到源码如
- tsconfig-paths-webpack-plugin
- Use this to load modules whose location is specified in the
paths
section oftsconfig.json
when using webpack. - This package provides the functionality of the
tsconfig-paths
package but as a webpack plug-in. - Using this plugin means that you should no longer need to add
alias
entries in yourwebpack.config.js
which correspond to the paths entries in yourtsconfig.json
. This plugin creates thosealias
entries for you, so you don't have to!
- Use this to load modules whose location is specified in the
- babel-plugin-module-resolver
- This plugin allows you to add new "root" directories that contain your modules.
- It also allows you to setup a custom alias for directories, specific files, or even other npm modules.
- terser-webpack-plugin
- uses terser to minify your JavaScript
- babel-plugin-transform-typescript-metadata
- Current
@babel/preset-typescript
implementation however just strips all types and does not emit the relative Metadata in the output code. - Babel plugin to emit decorator metadata like typescript compiler
- Current
- rimraf
- 作用是以包的形式封装rm -rf命令,用来删除文件和文件夹,不管文件夹是否为空,都可删
rm -rf
for node- 命令也可在windows下使用
- husky
- 能够防止不规范代码被commit、push、merge等等
- 在执行
git commit
之前会先执行script字段的precommit指定的命令,如yarn test - pre-commit包功能更灵活
- plop
- 设置好模板内容和生成文件路径后,可在命令行输入参数,自动生成组件到路径位置
- replace-in-file
- A simple utility to quickly replace text in one or more files or globs
- kkt
- Create React apps with no build configuration, Cli tool for creating react apps
- tsbb
- a zero-config CLI that helps you develop, test, and publish modern TypeScript Node.js project.
- TypeScript + Babel = TSBB
- KaTeX
- library for TeX math rendering on the web
- tslib
- tslib将仅用于您的编译目标不支持的功能,以便我们生出的代码更小