美文网首页Web 前端开发 让前端飞
从实际项目小谈react生命周期

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

作者: aermin | 来源:发表于2017-07-25 23:44 被阅读0次

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 )。

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

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

相关文章

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

    tips:接下去会在github写博客,简书不再更新和修改文章,欢迎大家逛逛我的新博客点击查看 ,我会尽量用更容易...

  • React生命周期

    React 生命周期 前言 React生命周期也是一个老生常谈的问题。项目上也是边摸索边用。 正文 在进行项目时,...

  • ES6经验总结

    我是从使用react开始在实际项目中使用es6语法的,转眼间已经过去了两年,中间从react到react-nati...

  • React 生命周期

    React 16.4 的生命周期图 早期React生命周期图 从图中,我们看到了一些变化 废弃的三个生命周期函数 ...

  • React组件的生命周期与调用历程

    react组件生命周期 英文文档介绍 目录 三种生命状态 八种生命周期钩子 生命周期钩子的实际调用顺序 一、 re...

  • React概念图

    React概念图 React组件生命周期概念图 参考文档:React入门教程 组件生命周期React:组件生命周期...

  • react+webpack项目实际开发应用

    react+webpack项目实际开发应用 在《react入门》和《react入门提高》中我讲了,react的基础...

  • react+webpack项目实际开发应用

    react+webpack项目实际开发应用 在《react入门》和《react入门提高》中我讲了,react的基础...

  • react+webpack项目实际开发应用

    react+webpack项目实际开发应用 在《react入门》和《react入门提高》中我讲了,react的基础...

  • React入门--组件生命周期

    React组件有自己的生命周期方法,React将组件从挂载(Mounting)-->更新(Updating)-->...

网友评论

    本文标题:从实际项目小谈react生命周期

    本文链接:https://www.haomeiwen.com/subject/raagkxtx.html