react 中使用setTimeout

React中使用setTimeout

setTimeout做轮询

  1. React由于是在内存中运行,所以即使是DOM对象已经被销毁了,如果在组件卸载(componentwillUnmount)的时候没有清楚掉定时器, setTimeout做循环还是会在内存中一直运行
componentwillUnmount() {
        this.state.brush && clearTimeout(this.state.brush)
    }

2.this.state.brush是指向定时器的指针 每次 setTimeout执行都需要更新这个指针

brushData = (time = this.state.brushtime,formdata = {
        wfid: this.state.wfid,begintime: this.state.time
    }) => {
        var brush = setTimeout(this.brushData,time * 5 * 1000);
        this.setState({brush})
        // 只有在表格数据返回之后才能再请求数据
        this.state.tableLoading || this.getPageData({...formdata},true)
    }

目标

使用setTimeout获取数据

getPageData = (formdata,brushing) => {
        // brushing 如果是自动轮询获取数据则brushing值为true 避免请求数据陷入死循环 这一步只能有submint事件触发 因为要更新表单值
        if (this.state.brushtime && !brushing) {
            // 保存表单值 以便setTImeout的回调函数(其实也就是getPageData)能取得请求数据时的参数
            formdata && this.setState({wfid: formdata.wfid,time: formdata.begintime});
            this.brushData(this.state.brushtime);
        } else {
            this.setState({tableLoading: true})
            if (!formdata) {
                // 初次加载
            } else {
                // 缓存当前页面选择的时间
            }
        }
    }
// brushData是回调函数 所以参数只能在当前作用域中取得
brushData = (time = this.state.brushtime) => {
        var brush = setTimeout(this.brushData,time * 5 * 1000);
        this.setState({brush})
        // 只有在表格数据返回之后才能再请求数据  并且在刷新页面数据的时候表单值传入null使请求数据的函数直接从state中取相应的表单值
        this.state.tableLoading || this.getPageData(null,true)
    }

相关文章

一、前言 在组件方面react和Vue一样的,核心思想玩的就是组件...
前言: 前段时间学习完react后,刚好就接到公司一个react项目...
前言: 最近收到组长通知我们项目组后面新开的项目准备统一技...
react 中的高阶组件主要是对于 hooks 之前的类组件来说的,如...
我们上一节了解了组件的更新机制,但是只是停留在表层上,例...
我们上一节了解了 react 的虚拟 dom 的格式,如何把虚拟 dom...