vue3-ts-util是下厨房几个vue3后台的通用函数,组件库。 使用ts编写而成,组件使用模板及少量tsx。
yarn add vue3-ts-util
按需可能会要求对等依赖 vue vuex vue-router,执行yarn add
见文档doc 目录见下方
- useDomRect hook风格获取dom的rect
- useEmit 用于在hook内emit
- useFetchQueueHelper/useStrictQueue/useRetryableQueue fetchqueue的hook wrapper
- useInfiniteScrolling 无限滚动
- useResizeable 用于鼠标拖拽调整调整某个元素的大小位置
- useStackAlloc hook风格管理object url分配
- useWatchDocument
document.addEventListener
的hook wrapper - createTypedShareStateHook/useHookShareState 生成一个实例内进行状态共享的hook
- useRouteId 路由参数id获取,合法判断
- FetchQueue 自动管理loading等的请求控制容器
- Task 轮训请求的控制
- makeAsyncIter 分页api的迭代管理
- useInfiniteScrolling 无限滚动
- useAntdListPagination / GeneralPagination 翻页管理
- deepComputed
- deepComputedEffect 更好的deepComputed
- deepComputedPick 执行后二值之间仍然会双向同步的pick
- deepProxy让defineModel也能进行深度响应
- events/typedEventEmitter 类型安全的EventEmitter
- image/getImageUrl 从下厨房用的图像结构构造url
- assigIncrId 生成一个全局自增id
- unid/typedID/ID 使用symbol实现的ID生成器
- delay,delayFn 延时,推迟控制流执行
- promise2ref promise转成ref
- promiseSetRef 在promise完成时设置某个ref
- dayjsConvert 一个函数实现下厨房常用的多种时间转换
- globalComponents
- DeepReadonly转换一个类型为深度只读
- ok 先验条件断言
- thruthy 真值断言
- Columns 描述antd表格结构的类型
- Image 下厨房的图像结构
- WithRequired 将对象部分字段转为不可空
- customPropType vue props用于推导自定义类型的辅助函数,使用interface风格写props
rollup-plugin-vue已经没维护,出现问题搞不定可以考虑vite
git clone ....
cd vue3-ts-util
yarn
....
大部分功能使用单元测试即可完成。
如果想要在其他项目中进行开发测试可以这么操作,以一个vite项目为例
不需要实时watch的可以跳过
import { defineConfig, searchForWorkspaceRoot, UserConfig } from 'vite'
export default defineConfig({
optimizeDeps: {
exclude: ['vue3-ts-util'] // 监听这个包的变化
},
server: {
watch: {
ignored: ['!**/node_modules/vue3-ts-util/es/**'],
},
fs: {
allow: [
searchForWorkspaceRoot(process.cwd()),
// 自定义规则
'/Users/xxxxxx/project/vue3-ts-util' // 本项目地址
]
}
}
})
在scripts的文件夹下创建conf.json
{
"devWatch": {
"symlink": "/Users/zanllp/try-fluent-design" // 直接在命令行里输入pwd获取
}
}
symlink
指向你开发&debug用的项目, 上面这个操作也可以通过npm link/yarn link 等代替,但是我感觉还不如直接用这个symlink, see https://github.com/yarnpkg/yarn/issues/1957。
再
yarn dev-watch # 开启即时编译
直接在这边修改src下面ts,tsx,vue,就可以即时在那边生效。做到近似在同一个项目内开发的体验。
需要注意的是关闭后目标项目还是使用的最后构建的包,如果需要改回去重新安装一遍vue3-ts-util
就行
yarn pre-release
再改下版本号,npm publish
即可发包
dev-watch
yarn import-optimize
可以在编译完的基础上进一步增强tree-shaking的效果,原理看scriprt文件夹下对应文件
yarn gen-vue-type
yarn build
yarn clean
yarn test
- vue组件的类型声明应该使用
yarn gen-vue-type
来自动生成,而不是手写或者使用shims,使用shims会丢失props的类型信息。对于props的声明应该尽量customPropType
,可以尽可能接近写interface的体验(setup的更好,直接defineProps) - 如果需要返回一个外部不可修改的对象可以使用
deepReadonly
- 修改文档后使用vscode的markdown in one更新所在文件的目录,然后使用
yarn gen-contents
生成合并的目录写入到readme - 尽可能足够的单元测试
- 如果修改了组件相关及时修改vetur下的文件,及volar所使用的
src/globalComponents.ts
- 版本号修改参考https://semver.org/lang/zh-CN/
vue3-ts-util有两个构建版本,使用ESM构建版本可以有效的减少编译后的体积
编译目标为es6,模块标准为es6,也是最主要使用的版本。优点是支持tree shaking。
参考这个issue #4
- 将webpack.config.js的optimization.sideEffects设为true
- 确保打包器内部的loader使用es module进行编译
- tsc有些直接在tsconfig.json就可以设置,有些需要传到加载器或者插件的参数里
- babel参考https://babeljs.io/docs/en/babel-preset-env#modules
如果上述无效可以参考这2篇文章
编译目标为es5,模块标准为commonjs,仅作为部分情况下的兼容,例如直接使用node运行
可以查看是否存在着多个vue实例,即vue3-ts-util和其他的组件不在同一个vue实例内,vue3-ts-util的ref另外一个实例收集不到。可以看看node_modules里面vue3-ts-util是否存在一个单独的vue安装,可以通过改变2者的npm package的vue版本依赖限制来解决这个问题
可以先判断是否是部分文件在编译完被移除掉了,即存在副作用的文件被编译器当成无副作用的处理了。判断可以通过开启source map编译,使用serve打开文件,进入页面后打开devtool的soucre查看是否缺少文件,如果确实是这个原因可以将缺少的文件添加到本项目的package.json
的sideEffects
里
当前的package.json
是这样
{
"sideEffects": [
"es/**/*.{vue,css}.js"
]
}
即匹配"es/**/*.{vue,css}.js"
的所有文件视为存在副作用,这两个是vue编译器生成的