博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TNG-Hooks:有状态逻辑在标准函数中的重用和组合
阅读量:6387 次
发布时间:2019-06-23

本文共 2578 字,大约阅读时间需要 8 分钟。

TNG-Hooks软件库出现之后,JavaScript开发人员可通过有用的、频繁有状态的和有效逻辑来装饰常规独立函数,例如查询远程数据库、访问范围外的上下文数据等。钩子函数(Hook)有助于代码重用和组合,可实现规模更小、更易于维护且更稳定的代码库。

正文

在去年的React大会,该组织发布了React Hooks项目,令各开发者社区大为赞叹。开发人员可使用Reack Hooks,将有状态或有效计算完全抽象为函数形式,进而在React函数组件中加以重用和组合。先前的做法是使用ES类而非函数,即用单独的纯计算函数添加效果和状态。

对经验不足的开发人员而言,使用函数要比ES类更易于组合代码。此外,使用ES类需要将有效逻辑位复制到各种各样的方法中,使代码散碎。TNG-Hooks在降低对React依赖的同时,有效利用了React Hooks的优点。

为了最小化React函数组件,TNG引入了一种称为“铰接函数”(Articulated Functions)的概念。铰接函数应满足两个条件。首先,在被调用前,它们需要包裹一个TNG装饰器(decorator)。其次,铰接函数可在执行过程中的某处调用钩子函数。

下面给出例子代码。其中,TNG函数作为装饰器,useState是一个钩子函数,而hit函数就是一个铰接函数。

function hit() {    var [count,updateCount] = useState(0);    count++;    updateCount(count);    console.log(`Hit count: ${count}`);}hit = TNG(hit);hit();       // Hit计数:1hit();       // Hit计数:2hit();       // Hit计数:3

在上例中,hit函数被多次调用,每次调用后返回不同的值。由此,我们称hit函数是一个有状态函数。钩子函数useState用于抽象本地状态管理操作,包括检索、存储和状态更新等。该钩子函数初始化状态变量count为0,并返回该变量值。函数updateCount更新该状态变量。

TNG-Hooks函数库还提供了useReducer、useEffect、useMemo、useCallback和useRef等钩子函数,每个钩子函数抽象了不同的有状态计算或有效计算。

此外,TNG软件库提供了仿React Custom Hooks的TNG Custom Hooks,用于支持开发人员自定义钩子函数。使用Custom Hooks,开发人员可通过重用现的有钩子函数去定义自己的钩子函数。TNG Custom Hooks并非铰接函数,而是标准JavaScript函数。铰接函数会在执行中某处调用钩子函数,而TNG Custom Hooks必须让自身也在铰接函数中调用。

// useHitCounter定义了一个Custom Hook,而不是一个铰接函数。function useHitCounter() {    // 继承TNG钩子函数的上下文。    var [count,updateCount] = useState(0);    count++;    updateCount(count);    return count;}// 两次铰接到TNG(..),每次均为点击按钮句柄(handler)。function onClick(evt) {    // 使用Custom Hook。    var hitCount = useHitCounter();    console.log(console.log(`Button #${evt.target.id}: ${hitCount}`);}var fooBtn = document.getElementById(\u0026quot;foo-btn\u0026quot;);var barBtn = document.getElementById(\u0026quot;bar-btn\u0026quot;);// 每个点击句柄都是铰接的`onClick()`。fooBtn.addEventListener(\u0026quot;click\u0026quot;,TNG(onClick),false);barBtn.addEventListener(\u0026quot;click\u0026quot;,TNG(onClick),false);

上例展示的Custom Hook函数useHitCounter并非铰接函数,它重用了给定的钩子函数useState。useHitCounter本身被onClick调用,而onClick是一个铰接函数。fooBtn和barBtn分别重用了同一自定义的有状态逻辑useHitCounter,该逻辑嵌在onClick事件句柄中。

TNG Hooks虽然参考了React项目,但它是一个全新的项目。TNG-Hooks软件库的作者Kyle Simpson给出了如下阐述:

TNG Hooks具有自身考虑和特定行为,它是一个独立项目。未来,TNG将继续保持与React Hooks的相似风格,但也会保持适当差异。

与React Hooks一样,铰接函数和钩子函数必须遵守一些调用规则。当前,并没有任何强制执行上述规则的机制,开发人员在违反规则时也不会给出警告,这可能会导致一些出错行为难以调试。此外,React Hooks是一种全新的实验性技术,还没决定哪些该做哪些不做。尽管TNG Hooks考虑到了React Hooks的一些经验教训,但还需要做更多测试以验证其最佳实践和存在的陷阱。

TNG Hooks支持通过tng-hooks npm package安装,据该软件包宣称,其测试代码覆盖率达100%。TNG Hooks以MIT许可开源发布,开发者可通过TNG-Hooks的GitHub项目页面给出反馈和贡献。

查看英文原文:

会议推荐

2019年6月,GMTC全球大前端技术大会2019即将到来。小程序、Flutter、移动AI、工程化、性能优化…大前端的下一站在哪里?点击下图了解更多详情。

转载地址:http://godha.baihongyu.com/

你可能感兴趣的文章
解决kubernetes中ingress-nginx配置问题
查看>>
蚂蚁金服核心技术:百亿特征实时推荐算法揭秘
查看>>
【直播回顾】云栖社区特邀专家徐雷Java Spring Boot开发实战系列课程(第19讲):Java Spring Cloud微服务架构模式与开发实战...
查看>>
学C++走游戏方向,是不是非常艰难自找苦吃?
查看>>
视频互动直播软件开发中的连麦问题分析
查看>>
【Jboss】热部署
查看>>
[开学季]“当高校遇到大数据”濮阳职业技术学院阿里云大数据应用学院举行阿里云开学第一课...
查看>>
KingShard MySQL中间件快速入门
查看>>
图的单源最短路径,Floyd算法(数据结构c++)
查看>>
MSSQL Sql加密函数 hashbytes 用法简介
查看>>
NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
查看>>
Swift 5 发布,ABI 终于稳定了
查看>>
微软输入法TSF SampleIME 代码浅说
查看>>
SQLServer CDC数据迁移和数据抽取功能介绍 2
查看>>
一个思维习惯,让你成为架构师
查看>>
前端面试题目汇总摘录(JS 基础篇 —— 2018.11.01更新)
查看>>
8大原因告诉你为什么要使用UPS电源和EPS电源,电气人都知道!
查看>>
Mybatis集成二级缓存与同时使用缓存与事务存在的坑
查看>>
Activity从创建到显示的整个过程
查看>>
从PRISM开始学WPF(四)Prism-Module?
查看>>