当前位置: 首页 > news >正文

北京网站模板cdq百度指数

北京网站模板,cdq百度指数,wordpress archive插件,公司网站后台维护怎么做1、问题描述 最近在写react的时候碰到了一个很奇怪的问题。 可以看到那个getXXX()的方法一直不断的被调用,网页一直请求,根本停不下来了。 2、产生原因 要弄明白这个原因,首先要先了解一下react生命周期。 react是组件式的编程,一…

1、问题描述

        最近在写react的时候碰到了一个很奇怪的问题。

 

         可以看到那个getXXX()的方法一直不断的被调用,网页一直请求,根本停不下来了。

2、产生原因

        要弄明白这个原因,首先要先了解一下react生命周期。

        react是组件式的编程,一个react项目启动以后,先是会加载好网页的DOM结构

         所谓的DOM结构,其实就是常见的一些web标签,比如<html>、<body>这些。就是绘制一个网页的基本框架。

         网页的DOM结构加载完以后,再去渲染react组件到页面上去(Mounting挂载阶段,把组件插入真实DOM)。调用了setState(useState的setState)后,就到了第二个Updating更新重新渲染(render)阶段。setState请求了好多次就是发生在Updating更新阶段。

        因为我是想在第一次打开这个页面的时候,就从后端请求数据,并把返回的数据渲染到页面上去,根据代码是顺序执行的,代码从上往下顺序执行,执行到getXXX()这个方法的时候,会请求后端以及渲染数据。但问题就出现在这里,getXXX()方法会被不断的调用!因为每次setState()的时候都会重新render一次页面(异步过程),于是整个页面的代码又会从头到尾执行一次。相当于每次render都会顺序把getXXX()里面的代码都顺序执行一下,每次render都又加了新的setState,然后无限嵌套,递归的这种......

3、解决方法

        注:因为不方便直接贴公司的代码,这里我就用自己写的Demo了。

3.1、使用useEffect函数

        在listAllPeople()方法外面再加一层方法getData(),在useEffect里面调用getData(),并把useEffect的第二个参数为[ ],表示只在第一次render的时候调用一下。

const getData=()=>{//get请求无参数listAllPeople().then((response) => {const result = response.data;console.log(response);console.log(result);setpeopleDTOList(result.PeopleDTOList);console.log(peopleDTOList)});
};useEffect(() => {getData();
}, []);

         然后你会发现,useEffect()调用了两次getData()方法,这是由于严格模式下为了确保请求响应成功,所以特地多执行了一次useEffect。当然如果你不想请求两次的话,也可以取消严格模式。找到入口页面的<React.StrictNode>并删除就退出严格模式了。

         退出严格模式后,useEffect就只执行了一次了。

4、总结

        无

5、参考资料

React useEffect 两个参数你用对了吗 - 掘金

react 严格模式(控制台调用两次问题)_使用react.strictmode,接口调用两次_轻狂的书生的博客-CSDN博客

使用 Effect Hook – React (reactjs.org)

Hook 简介 – React (reactjs.org)

react 严格模式(控制台调用两次问题)_使用react.strictmode,接口调用两次_轻狂的书生的博客-CSDN博客 react关闭严格模式-掘金 (juejin.cn)

react 严格模式(控制台调用两次问题)_使用react.strictmode,接口调用两次_轻狂的书生的博客-CSDN博客

防止 React 触发 useEffect 两次 - 知乎 (zhihu.com)

useEffect – React

深入详解React生命周期 - 掘金 (juejin.cn)

React 组件生命周期 | 菜鸟教程 (runoob.com)

HTML DOM 教程 | 菜鸟教程 (runoob.com)

http://www.yidumall.com/news/37329.html

相关文章:

  • 婚礼做的好的婚庆公司网站培训课程有哪些
  • 石狮网站建设价格广州seo网站开发
  • 如何制作手机网站模板seo信息查询
  • 小语种网站建设及推广seo公司网站推广
  • 廊坊网站建设济南seo培训
  • 兰州官网seo分析电商seo名词解释
  • wordpress获取文章信息合肥网站快速优化排名
  • 网站开发研究生站长之家最新域名查询
  • iis 网站制作常用的seo工具
  • 网站做百度收录的意义网站整站优化公司
  • 贵阳做网站的大公司有哪些长春seo结算
  • 武汉网页设计高级培训学校黑帽seo之搜索引擎
  • 网站开发文档模板济南百度推广优化
  • 西安网站建设bieleng来几个关键词兄弟们
  • java做网站开发的流程国际羽联最新排名
  • b2c的电子商务的网站建设b站推广是什么意思
  • b2b网站做网络推广有用吗企业邮箱登录入口
  • 柳州正规网站建设加盟iis搭建网站
  • 吴忠门户网站建设2022小说排行榜百度风云榜
  • wordpress内部优化seo综合查询软件排名
  • 简述网页制作的步骤安徽网络关键词优化
  • 作网站seo服务是什么
  • 建设网站的网站有哪些品牌搜索引擎服务优化
  • 做网站需要准备什么东西百度云怎么找资源
  • 临沂网站建设微信青岛seo网络优化公司
  • 成都电子网站建设多少钱网络平台推广是干什么
  • 使用国外空间的网站外贸平台自建站
  • 建立网站的风险抖音搜索关键词推广
  • 知名seo网站优化公司郑州seo排名优化
  • 循环视频做网站背景拉新人拿奖励的app