该系列已更新文章:

分享一个实用的 vite + vue3 组件库脚手架工具,提升开发效率

开箱即用 yyg-cli 脚手架:快速创建 vue3 组件库和vue3 全家桶项目

Vue3 企业级优雅实战 - 组件库框架 - 1 搭建 pnpm monorepo

Vue3 企业级优雅实战 - 组件库框架 - 2 初始化 workspace-root

Vue3 企业级优雅实战 - 组件库框架 - 3 搭建组件库开发环境

Vue3 企业级优雅实战 - 组件库框架 - 4 组件库的 CSS 架构

本文继续组件库开发环境的搭建,前面两篇分别介绍了组件库中组件项目的初始化、组件库 CSS 架构,本文介绍通用工具库的搭建。在组件开发过程中,可能会调用一些通用的工具函数,这些工具函数便可以提取到一个独立的 npm 包中。

1 创建工具包

1.1 初始化工具包

到目前为止,packages 目录下有三个包:foo 示例组件、scss 样式、yyg-demo-ui 组件库聚合,现创建第四个:utils

在命令行中进入 utils 目录,使用 pnpm 初始化。

pnpm init

修改自动生成的 package.json 文件中的 namemain ,内容如下:

{
"name": "@yyg-demo-ui/utils",
"version": "1.0.0",
"description": "通用工具函数",
"main": "index.ts",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC"
}

由于工具包咱们也采用 TypeScript 编写,在 utils 下也提供一份 tsconfig.json 文件:

{
"compilerOptions": {
"target": "es2015",
"lib": [
"es2015"
],
"module": "commonjs",
"rootDir": "./",
"allowJs": true,
"isolatedModules": false,
"esModuleInterop": true,
"forceConsistentCasingInFileNames": true,
"strict": true,
"skipLibCheck": true
}
}

1.2 编写第一个工具函数

需求描述:组件间通信是一个刚需,当组件层级较多时,可以使用全局总线来通信。Vue 2.x 中通常使用 EventBus 作为全局总线,而 Vue 3.x 可以使用 mittmitt 体积小,支持全部事件的监听和批量移除,不依赖 Vue 实例,可以跨框架使用。咱们的第一个工具函数就是简单封装 mitt,导出 mitt 对象即可。

首先在 utils 包下安装 mitt 依赖:

pnpm install mitt@1.1.3

细心的同学会发现,在引入 mitt 时优雅哥指定了版本号 1.1.3,这是因为,优雅哥在使用当前最新的 3.0.0 版本时一直提示类型错误或找不到类型声明文件,由于没空处理,就简单粗暴的降到 1.1.3 版本。

utils 目录下创建源码目录 src,并在 src 中创建 emitter.ts 文件。

utils/src/emitter.ts

import mitt from 'mitt'
const Mitt = mitt
export const emitter: mitt.Emitter = new Mitt() export default emitter

上面的第二行代码看着多余,因为本质上就是 new mitt(),这么做是为了满足 eslint 的规则:

A constructor name should not start with a lowercase letter.

1.3 编写第二个工具函数

上面的 emitter 对象会在后面的组件开发中使用到,在 foo 中并未使用到,所以咱们再创建一个测试使用的工具函数。

utils/src/ 目录下创建 test-log.ts 文件:

export const testLog = (str: string) => {
console.log('test log: ', str)
}

1.4 入口文件

前面的 package.json 中指定了 mainindex.ts,在 utils 目录下创建 index.ts 文件,导入并导出所有的工具函数等。

export { emitter } from './src/emitter'
export { testLog } from './src/test-log'

总结一下,组件库通用工具包的目录结构如下:

packages/
|- utils/
|- src/
|- emitter.ts
|- test-log.ts
|- index.ts
|- tsconfig.json
|- package.json

2 在组件中使用工具包

2.1 安装依赖

前面已经开发了 foo 示例组件,如果该组件要使用工具包,首先需要安装依赖。在命令行中进入 foo 目录:

pnpm install @yyg-demo-ui/utils

执行后 foo 的 package.json 中会多了一行依赖:

"dependencies": {
"@yyg-demo-ui/utils": "workspace:^1.0.0"
}

2.2 使用工具

由于 utils 包指定了 mainindex.ts,并且所有的工具都在 index.ts 中导入并导出,所以在使用时只需引入 utils 包即可。

例如要使用上面创建的 testLog 函数,则只需要在代码中如下引入:

import { testLog } from '@yyg-demo-ui/utils'

setup 中的按钮点击事件调用该方法:

const onBtnClick = () => {
console.log('点击按钮测试', props.msg)
testLog(props.msg)
}

后面再开发过程中如果新增工具函数:如 JSON Schema 的解析等,则往 utils 中添加即可,并在 utils/index.ts 中统一将其导入并导出。

感谢你阅读本文,如果本文给了你一点点帮助或者启发,还请三连支持一下,点赞、关注、收藏,程序员优雅哥会持续与大家分享更多干货

Vue3 企业级优雅实战 - 组件库框架 - 5 组件库通用工具包的更多相关文章

  1. Vue3 企业级优雅实战 - 组件库框架 - 1 搭建 pnpm monorepo

    前两篇文章分享了基于 vite3 vue3 的组件库基础工程 vue3-component-library-archetype 和用于快速创建该工程的工具 yyg-cli,但在中大型的企业级项目中,通 ...

  2. Vue3 企业级优雅实战 - 组件库框架 - 3 搭建组件库开发环境

    前文已经初始化了 workspace-root,从本文开始就需要依次搭建组件库.example.文档.cli.本文内容是搭建 组件库的开发环境. 1 packages 目录 前面在项目根目录下创建了 ...

  3. Vue3 企业级优雅实战 - 组件库框架 - 2 初始化 workspace-root

    上文已经搭建了 pnpm + monorepo 的基础环境,本文对 workspace-root 进行初始化配置,包括:通用配置文件.公共依赖.ESLint. 1 通用配置文件 在项目 根目录 下添加 ...

  4. Vue3 企业级优雅实战 - 组件库框架 - 4 组件库的 CSS 架构

    在前一篇文章中分享了搭建组件库的基本开发环境.创建了 foo 组件模块和组件库入口模块,本文分享组件库的样式架构设计. 1 常见的 CSS 架构模式 常见的 CSS 架构模式有很多:OOCSS.ACS ...

  5. Vue企业级优雅实战04-组件开发01-SVG图标组件

    (后续的文章 公众号会提前一周更新,欢迎关注文末的微信公众号:程序员搞艺术) 预览本文的实现效果: # gitee git clone git@gitee.com:cloudyly/dscloudy- ...

  6. Vue企业级优雅实战-00-开篇

    从2018.1.开始参与了多个企业的中台建设,这些中台的技术选型几乎都是基于 Spring Cloud 微服务架构 + 基于 Vue 全家桶的前端.我前后端架构及开发我几乎各占一半的精力,在企业级前端 ...

  7. Vue企业级优雅实战05-框架开发01-登录界面

    预览本文的实现效果: # gitee git clone git@gitee.com:cloudyly/dscloudy-admin-single.git # github git clone git ...

  8. Vue企业级优雅实战03-准备工作04-全局设置

    本文包括如下几个部分: 初始化环境变量文件 JS 配置文件初始化:如是否开启 Mock 数据.加载本地菜单.URL 请求路径等: 国际化文件初始化:初始化国际化文件的结构: 整合 Element UI ...

  9. Vue企业级优雅实战02-准备工作03-提交 GIT 平台

    代码管理.版本管理是件老大难的事情,尤其多人开发中的代码冲突.突击功能时面临的 hotfix 等.本文只是简单说说如何将一套代码提交到两个 Git 平台(GitHub.GitEE)上.其他的 Git ...

  10. 《Ext JS模板与组件基本框架图----组件》

    本节主要从七个方面讲解组件,组件时什么,它的作用,它的构架,以及怎么创建和周期还有常见的配置项,属性方法和事件以及其层级是什么都进行整理,希望对大家有帮助. 组件的基础知识.png 2 Abstrac ...

随机推荐

  1. Python入门系列(七)开发常说的“累”与“对象”

    类与对象 Python是一种面向对象的编程语言. 要创建类,请使用关键字class class MyClass: x = 5 创建一个名为p1的对象,并打印x的值 p1 = MyClass() pri ...

  2. KingbaseES V8R6集群管理运维案例之---repmgr standby switchover故障

    案例说明: 在KingbaseES V8R6集群备库执行"repmgr standby switchover"时,切换失败,并且在执行过程中,伴随着"repmr stan ...

  3. 如何自动清理 KingbaseES SYS_LOG

    KingbaseES 初始化完成后,默认不会对 sys_log进行清理.如果需要对sys_log进行自动清理,需要设置相关参数. 与日志自动清理有关的参数(默认值)如下: log_filename | ...

  4. [Golang] GO 语言工作环境的基本概念

    1. GOPATH 和 GOROOT(环境变量) 1. GOROOT go 编译器.标准库等安装的地方,所有我们写的代码其实都是文本文件而已,需要编译器等工具将其加工成可执行文件或者库文件才能使用,每 ...

  5. thinkphp5.1 cookie跨域、thinkphp5.1 session跨域、tp5.1cookie跨域

    cookie跨域: //config/cookie.php return [ //... //仅7.3.0及以上适用 'samesite' => 'None', //是否加密cookie值,fa ...

  6. Linux宝塔后台管理地址使用SSL,并部署非443端口的https

    上传你的key和pem,然后点设置 点击配置文件 插入代码 1 ssl on; 2 ssl_certificate /xxx/yyy/zzz.pem; 3 ssl_certificate_key /x ...

  7. .NET WebAPI 自定义 NullableConverter 解决请求入参 “”空字符触发转换异常问题

    最近在项目中启用了Nullable 可为空的类型,这个特性确实很好用,在 WebAPI 的入参上可以直接采用 ? 来标记一个字段是否允许为空,但是使用过程中遇到了如下一个问题,比如创建部门接口 我们定 ...

  8. Java 加载、编辑和保存WPS表格文件(.et/.ett)

    WPS表格文件是金山开发的专门用于处理表格数据的Office工具,属于WPS Office中WPS文字.WPS表格和WPS演示三大功能模块之一.通常以.et和.ett作为文件后缀.我们在通过后端来操作 ...

  9. 使用 EFKLK 搭建 Kubernetes 日志收集工具栈

    转载自:https://mp.weixin.qq.com/s?__biz=MzU4MjQ0MTU4Ng==&mid=2247491992&idx=1&sn=a770252759 ...

  10. 类和实例,super()函数

    class Foo: def __init__(self, name): self.name = name def ord_func(self): """定义实例方法,至 ...