从实际项目小谈react生命周期

tips:接下去会在github写博客,简书不再更新和修改文章,欢迎大家逛逛我的新博客点击查看 ,我会尽量用更容易理解的方式写好每一篇博客,大家一起学习交流😄。

前言

今天写的一个react版的滚动字幕,思路是用js操作展示内容的scrollWidth,然后用setInterval 循环调用function ,function内容大体思路是对文字内容userDOM.style.transform = 'translateX(-'+ i +'px)',每次横向左移动ipx的距离,形成滚动效果,当i>=scrollWidth的时候,将i归零,形成循环滚动。(这里操作了dom,不是很好)

这里先解释一下浏览器scrollWidth,scrollWidth,offsetWidth三种宽度的区别
情况1:
元素内无内容或者内容不超过可视区,滚动不出现或不可用的情况下。
scrollWidth=clientWidth,两者皆为内容可视区的宽度。
offsetWidth为元素的实际宽度。
情况2:
元素的内容超过可视区,滚动条出现和可用的情况下。
scrollWidth>clientWidth。
scrollWidth为实际内容的宽度。
clientWidth是内容可视区的宽度。
offsetWidth是元素的实际宽度。

出问题了

为了以便调用后端接口前先模拟展示,将静态生成的内容写死的文字内容换成动态加载,还采取了随机生成用户ip和获奖内容,结果获取到的scrollWidth(元素内容的实际宽度,包括被隐藏的部分)只是内容可视区的宽度,显然是不行的,所以无法滚动全部,我们需要的是元素内容的实际宽度。为什么会出现这种情况呢?如果文字内容是静态生成的,内容写死的,并不会出现这种问题。

问题出在哪里?

出在动态加载还要考虑到react的生命周期,componentWillMount(将要挂载)->render(dom渲染)->componentDidMount(已经挂载),这个滚动函数写在了componentDidMount中,也就是页面dom结构渲染完了文字内容才开始动态生成,结果scrollWidth抓取到的文字内容是空的,只能获取了内容可视区的宽度。


网上找的一张react生命周期的好图

问题找出来了,该如何解决呢?

最简单粗暴的方式就是把动态加载文字内容的函数放在componentWillMount(将要挂载)中,在render页面之前就把该部分内容加载完毕,这样render页面的时候scrollWidth将抓取到早已加载好的文字内容了,可是这样会造成打开页面后,页面空白一会,在渲染出页面的内容来,这段空白期间就是componentWillMount加载你的数据内容去了。如果数据内容少还好说,万一量很大了,那就尴尬了,严重影响用户体验。

更好的解决办法是

仍把动态加载文字内容的函数放在componentDidMount中,并在此采用window.onload 调用滚动函数,也就是等页面都渲染完了,文字内容也ok了,才会调用滚动函数(scrollWidth,setInterval,transform )。

这下,解决了生命周期以及用户体验,加载性能的问题。😀

如有错误和不足,恳请指出指导^ ^

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Window和document对象的区别 window对象window对象表示浏览器中打开的窗口window对象是...
    FConfidence阅读 2,257评论 0 5
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,815评论 1 92
  • 变量命名、声明、赋值 1.必须以字母、下划线或美元符号开头,后面可以跟字母、下划线、美元符号和数字。2.变量名区分...
    wq04200阅读 647评论 0 1
  • 文/逗逗 图/摄图网 路过的行人那么多,却没有人愿意为你驻足停留? 来光顾过一次之后,你们再也没有交集可言了? ...
    遇见逗逗阅读 291评论 0 0
  • 她们在不同的岗位上,巾帼不让须眉,奋发图强,贡献自己的力量,在艺术的道路上,她们仍执着的追求,行走在前进...
    禹乡墨韵书画阅读 572评论 2 4