当前位置:首页 > 科技  > 软件

有时候,技术问题的最优解并不是从技术考虑

来源: 责编: 时间:2024-01-15 09:22:12 327观看
导读大家好,我卡颂。最近我们技术群发生个事儿,我觉得还挺有代表性的。有时候,技术问题的最优解并不是从技术考虑。对于工作时间不长的程序员,这篇文章可能对你有帮助。事情起因事情起因是一位同学在群里问:“怎么获取react el

SFT28资讯网——每日最新资讯28at.com

大家好,我卡颂。SFT28资讯网——每日最新资讯28at.com

最近我们技术群发生个事儿,我觉得还挺有代表性的。有时候,技术问题的最优解并不是从技术考虑。SFT28资讯网——每日最新资讯28at.com

对于工作时间不长的程序员,这篇文章可能对你有帮助。SFT28资讯网——每日最新资讯28at.com

事情起因

事情起因是一位同学在群里问:“怎么获取react element对应dom中的文本?”SFT28资讯网——每日最新资讯28at.com

SFT28资讯网——每日最新资讯28at.com

为什么想获取文本内容呢,原来他是想做「交互的打点上报功能」SFT28资讯网——每日最新资讯28at.com

SFT28资讯网——每日最新资讯28at.com

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

那么类似“用户点击了一个按钮,我想知道这个按钮是否在对话框中,如果在,取出对话框的标题上报”就无法实现。SFT28资讯网——每日最新资讯28at.com

想一想,如果是你,会怎么实现这个功能呢?SFT28资讯网——每日最新资讯28at.com

功能实现

这位同学的做法是 —— 梳理现有业务逻辑中的组件层级,从特定的层级里拿数据。SFT28资讯网——每日最新资讯28at.com

比如Modal组件的标题渲染成HTML是:SFT28资讯网——每日最新资讯28at.com

<div>  <h1>这里是标题</h1></div>

那么他会按div -> h1这样的层级结构取标题数据。具体实现还涉及很多hack的方法。SFT28资讯网——每日最新资讯28at.com

比如,组件没有挂载时如何获取数据?他通过把组件挂载在一个离屏DOM上,再分析他:SFT28资讯网——每日最新资讯28at.com

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

再比如,如何根据DOM不同,增加一些特殊的属性呢?可以覆写jsx、React.createElement方法。SFT28资讯网——每日最新资讯28at.com

问题

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

一个打点上报功能硬生生开发成了爬虫功能。SFT28资讯网——每日最新资讯28at.com

但是,这位同学并不觉得这有问题。从他的回答看,他的思想是 —— 技术问题就应该交给技术解决。SFT28资讯网——每日最新资讯28at.com

SFT28资讯网——每日最新资讯28at.com

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

就本文的例子来说,一种合理的解决方式是:SFT28资讯网——每日最新资讯28at.com

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

总结

作为搞通用服务的同学,要接近业务,又不能让自己陷入业务。SFT28资讯网——每日最新资讯28at.com

回到本文的例子,如果你替业务同学实现了业务逻辑打点上报还不知会他们。未来业务需求变化导致代码变化后,打点上报有误,这是谁的锅呢?SFT28资讯网——每日最新资讯28at.com

业务同学会说:我根本不知道打点这回事儿啊。SFT28资讯网——每日最新资讯28at.com

到时候你就欲哭无泪了。SFT28资讯网——每日最新资讯28at.com

所以,明确自己的工作职责,做好向上管理,不是所有技术问题都得靠技术解决。SFT28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-60998-0.html有时候,技术问题的最优解并不是从技术考虑

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 我愿称之为开源界最好用的行为验证码

下一篇: 面试官问:synchronized为什么是重量级锁?

标签:
  • 热门焦点
  • 小米官宣:2023年上半年出货量中国第一!

    今日早间,小米电视官方微博带来消息,称2023年小米电视上半年出货量达到了中国第一,同时还表示小米电视的巨屏风暴即将开始。“公布一个好消息2023年#小米电视上半年出货量中国
  • 7月安卓手机性价比榜:努比亚+红魔两款新机入榜

    7月登场的新机有努比亚Z50S Pro和红魔8S Pro,除了三星之外目前唯二的两款搭载超频版骁龙8Gen2处理器的产品,而且努比亚和红魔也一贯有着不错的性价比,所以在本次的性价比榜单
  • 7月安卓手机性能榜:红魔8S Pro再夺榜首

    7月份的手机市场风平浪静,除了红魔和努比亚带来了两款搭载骁龙8Gen2领先版处理器的新机之外,别的也想不到有什么新品了,这也正常,通常6月7月都是手机厂商修整的时间,进入8月份之
  • Rust中的高吞吐量流处理

    作者 | Noz编译 | 王瑞平本篇文章主要介绍了Rust中流处理的概念、方法和优化。作者不仅介绍了流处理的基本概念以及Rust中常用的流处理库,还使用这些库实现了一个流处理程序
  • 在线图片编辑器,支持PSD解析、AI抠图等

    自从我上次分享一个人开发仿造稿定设计的图片编辑器到现在,不知不觉已过去一年时间了,期间我经历了裁员失业、面试找工作碰壁,寒冬下一直没有很好地履行计划.....这些就放在日
  • 一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    作者:Hiu 来源:互联网品牌官01 擦边少女空降热搜,幕后推手曝光被网友誉为&ldquo;纯欲天花板&rdquo;的女网红井川里予,近期因为一组哥特风照片登上热搜,引发了一场互联网世界关于
  • 年轻人的“职场羞耻感”,无处不在

    作者:冯晓亭 陶 淘 李 欣 张 琳 马舒叶来源:燃次元&ldquo;人在职场,应该选择什么样的着装?&rdquo;近日,在网络上,一个与着装相关的帖子引发关注,在该帖子里,一位在高级写字楼亚洲金
  • 三星获批量产iPhone 15全系屏幕:苹果史上最惊艳直屏

    按照惯例,苹果将继续在今年9月举办一年一度的秋季新品发布会,有传言称发布会将于9月12日举行,届时全新的iPhone 15系列将正式与大家见面,不出意外的话
  • OPPO K11样张首曝:千元机影像“卷”得真不错!

    一直以来,OPPO K系列机型都保持着较为均衡的产品体验,历来都是2K价位的明星机型,去年推出的OPPO K10和OPPO K10 Pro两款机型凭借各自的出色配置,堪称有
Top