有时候,技术问题的最优解并不是从技术考虑
创始人
2025-07-10 21:40:42
0

大家好,我卡颂。

最近我们技术群发生个事儿,我觉得还挺有代表性的。有时候,技术问题的最优解并不是从技术考虑。

对于工作时间不长的程序员,这篇文章可能对你有帮助。

事情起因

事情起因是一位同学在群里问:“怎么获取react element对应dom中的文本?”

为什么想获取文本内容呢,原来他是想做「交互的打点上报功能」

他希望这个打点上报功能是完全自动化、业务无感知的。但这里存在一个悖论:如果打点上报是“业务无感知的”,那打点功能肯定要和业务解耦。既然和业务解耦,就无法记录“业务的完整操作链路”。

那么类似“用户点击了一个按钮,我想知道这个按钮是否在对话框中,如果在,取出对话框的标题上报”就无法实现。

想一想,如果是你,会怎么实现这个功能呢?

功能实现

这位同学的做法是 —— 梳理现有业务逻辑中的组件层级,从特定的层级里拿数据。

比如Modal组件的标题渲染成HTML是:

这里是标题

那么他会按div -> h1这样的层级结构取标题数据。具体实现还涉及很多hack的方法。

比如,组件没有挂载时如何获取数据?他通过把组件挂载在一个离屏DOM上,再分析他:

function analyzeCpn(node: ReactNode) {
  const div = document.createElement('div');
  const root = reactDOM.createRoot(div);
  flushSync(() => root.render(node));
  // ...分析 div.innerHTML
}

再比如,如何根据DOM不同,增加一些特殊的属性呢?可以覆写jsx、React.createElement方法。

问题

这么实现,当前项目确实没问题。但有个很现实的问题:随着业务不断迭代,如果哪天组件结构变了,按以往结构获取数据就会失败,难道我还得跟着业务一起改打点上报代码么?

一个打点上报功能硬生生开发成了爬虫功能。

但是,这位同学并不觉得这有问题。从他的回答看,他的思想是 —— 技术问题就应该交给技术解决。

实际上有时候,技术问题的最优解并不是从技术考虑。就像遇到产品的不合理需求,我们首先思考的,不应该是“如何实现他”,而是“从哪个角度把需求怼回去”。

就本文的例子来说,一种合理的解决方式是:

  • 调研一下主流打点上报库的实现逻辑。
  • 调研完毕后和领导沟通。
  • 沟通好后让领导拉个会,会上把你的方案跟大家同步一下,让大家知道上报方案如何实现。
  • 各个业务同学认领自己那部分的打点上报需求,遇到技术问题和你沟通,你辅助解决。

总结

作为搞通用服务的同学,要接近业务,又不能让自己陷入业务。

回到本文的例子,如果你替业务同学实现了业务逻辑打点上报还不知会他们。未来业务需求变化导致代码变化后,打点上报有误,这是谁的锅呢?

业务同学会说:我根本不知道打点这回事儿啊。

到时候你就欲哭无泪了。

所以,明确自己的工作职责,做好向上管理,不是所有技术问题都得靠技术解决。

相关内容

热门资讯

PHP新手之PHP入门 PHP是一种易于学习和使用的服务器端脚本语言。只需要很少的编程知识你就能使用PHP建立一个真正交互的...
网络中立的未来 网络中立性是什... 《牛津词典》中对“网络中立”的解释是“电信运营商应秉持的一种原则,即不考虑来源地提供所有内容和应用的...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
什么是大数据安全 什么是大数据... 在《为什么需要大数据安全分析》一文中,我们已经阐述了一个重要观点,即:安全要素信息呈现出大数据的特征...
如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
P2P的自白|我不生产内容,我... 现在一提起P2P,人们就会联想到正在被有关部门“围剿”的互联网理财服务。×租宝事件使得劳...
Intel将Moblin社区控... 本周二,非营利机构Linux基金会宣布,他们将担负起Moblin社区的管理工作,而这之前,Mobli...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...