【原创发布】typechecker:一款轻量级 JS 模板化类型检查工具

【原创发布】typechecker:一款轻量级 JS 模板化类型检查工具

前言

在纯 JavaScript 开发中,我们常常面临类型不严谨导致的隐蔽 Bug,而引入 TypeScript 又会增加项目的学习和迁移成本。基于此,我开发了一款轻量级、无依赖的类型检查工具 @dongxiang678/typechecker,并已正式发布到 NPM 仓库,无需 TS 即可实现类 C++ 模板风格的强类型校验!

📦 包发布信息

✨ 核心作用

  1. 模板化类型约束 :模拟 C++ 模板 Checker<T> 风格,为任意类型创建专属检查器,杜绝类型混用;
  2. 函数类型强校验:强制校验函数入参和返回值类型,类型不匹配直接抛出明确错误;
  3. 支持自定义类:不仅支持 String/Number 等基础类型,还能对自定义类做精准类型校验;
  4. 轻量级无依赖:纯原生 JS 实现,体积仅 13KB,可无缝集成到任意 JS 项目(前端/Node.js)。

🚀 快速使用

1. 安装
bash 复制代码
# npm 安装
npm install @dongxiang678/typechecker --save

# yarn 安装
yarn add @dongxiang678/typechecker
2. 基础类型校验示例
javascript 复制代码
// 导入工具
const { createCheckerTemplate, enforceReturnType } = require('@dongxiang678/typechecker');

// 创建 String 类型检查器
const StringChecker = createCheckerTemplate(String);

// 强制函数返回 StringChecker 类型
const getValidString = enforceReturnType(StringChecker, (value) => {
  const checker = new StringChecker();
  return checker.check(value); // 仅接受 String 类型值
});

// 正常使用(返回 String 类型)
console.log(getValidString("Hello typechecker!").getValue()); // 输出:Hello typechecker!

// 类型错误示例(传入 Number 会直接报错)
try {
  getValidString(123);
} catch (err) {
  console.error(err.message); // 输出:返回值类型错误:Checker<Number> 无法转换为 Checker<String>
}
3. 自定义类校验示例
javascript 复制代码
const { createCheckerTemplate, enforceFunctionType } = require('@dongxiang678/typechecker');

// 自定义 User 类
class User {
  constructor(name) {
    this.name = name;
  }
}

// 创建 User 类型检查器
const UserChecker = createCheckerTemplate(User);

// 强制函数参数和返回值均为 UserChecker 类型
const getUserInfo = enforceFunctionType([UserChecker], UserChecker, (userChecker) => {
  return userChecker.check(new User("董翔"));
});

// 正常使用
const userChecker = new UserChecker(new User("测试用户"));
console.log(getUserInfo(userChecker).getValue().name); // 输出:董翔

🎯 适用场景

  • 纯 JS 项目的类型安全加固,避免因类型问题导致的隐蔽 Bug;
  • 团队协作项目中,强制规范函数入参/返回值类型;
  • 无需引入 TS,快速实现轻量级强类型校验;
  • 前端/Node.js 项目通用,无环境限制。

📄 开源协议

本工具采用 MIT 开源协议,可自由使用、修改、分发,欢迎各位开发者 Star/Fork 提优化建议!

最后

如果在使用过程中遇到问题,可通过 NPM 包主页的邮箱(3631247406@qq.com)联系我,也欢迎在评论区交流反馈~


相关推荐
实心儿儿1 小时前
C++ —— 继承
开发语言·c++
A_nanda2 小时前
vue实现走马灯显示文字效果
前端·javascript·vue.js
佛系豪豪吖2 小时前
OpenClaw(龙虾)彻底卸载教程|Windows+Mac通用,3步无残留
开发语言
AMoon丶2 小时前
C++基础-类、对象
java·linux·服务器·c语言·开发语言·jvm·c++
为搬砖记录2 小时前
杰理AC695N soundbox 3.1.2打开ble宏的编译bug
c语言·开发语言·单片机·bug
晴栀ay2 小时前
一文详解JS中的执行顺序——事件循环(宏任务、微任务)
前端·javascript·面试
0vvv02 小时前
JavaScript-1
javascript
张元清2 小时前
React 19 Hooks:新特性及高效使用指南
前端·javascript·面试
y = xⁿ2 小时前
【Java八股锁机制的认识】synchronized和reentrantlock区分,锁升级机制
java·开发语言·后端