react列表中,当key改变后发生的事情

Main.jsx

export default class Main extends PureComponent {
    constructor(props) {
        super(props);
        this.state = {
            list: [
                {
                    key: 0,
                    value: 1
                },
                {
                    key: 1,
                    value: 2
                },
                {
                    key: 2,
                    value: 3
                }
            ]
        }
        this.setKey = ::this.setKey;
    }

    componentWillMount() {
        console.log('main will mount');
    }

    componentDidMount() {
        console.log('main did mount');
    }

    componentWillUpdate() {
        console.log('main will update');
    }

    componentDidUpdate() {
        console.log('main did update');
    }

    componentWillUnmount() {
        console.log('main will unmount');
    }

    setKey() {
        const { list } = this.state;

        this.setState({
            list: Array.from(list, item => {
                return Object.assign(item, {
                    key: item.key + 1
                });
            })
        });
    }

    render() {
        const { list } = this.state;
        return (
            <div>
                {list.map(item => <List key={item.key} value={item.value} />)}
                <button onClick={this.setKey}>key</button>
            </div>
        )
    }
}
        

List.jsx

export default class List extends PureComponent {
    constructor(props) {
        super(props);
    }

    componentWillMount() {
        console.log(`list${this.props.value} will mount`);
    }

    componentDidMount() {
        console.log(`list${this.props.value} did mount`);
    }

    componentWillUpdate() {
        console.log(`list${this.props.value} will update`);
    }

    componentDidUpdate() {
        console.log(`list${this.props.value} did update`);
    }

    componentWillUnmount() {
        console.log(`list${this.props.value} will unmount`);
    }

    render() {
        const { value } = this.props;
        return(
            <div>
                list{value}
            </div>
        )
    }
}

当点击key按钮后会发生什么呢?先分析一下

转载于:https://www.cnblogs.com/hefenghefeng/p/7008495.html

// 数据 const getTotalBeforeData = function () { axiosPost("/user/total/SearchByDateAndName", param, t).then((res) => { // 表头名 const s1 = res.data.data.tableName.map((header: any, index: any) => ({ title: header, dataIndex: header, key: header, fixed: index < 4 ? "left" : undefined, // 固定前6列 width: index === 0 ? 50 : index === 2 ? 320 : 90, onHeaderCell: () => ({ style: { backgroundColor: '#769fcd' } }) }) ) s1[0].title = "no" s1[3].title = "実績工数" setColumns(s1) // 表内容 for (let index = 0; index < res.data.data.tableData.length; index++) { res.data.data.tableData[index].id = index + 1 } setDataSource(res.data.data.tableData) // 合计 const length = s1.length let s2: any = [] var totalKeys = Object.keys(res.data.data.statistics) var totalValues = Object.values(res.data.data.statistics) for (let index = 3; index < length; index++) { for (let i = 0; i < totalKeys.length; i++) { const totalKey = totalKeys[i]; const totalValue = totalValues[i]; if (totalKey == s1[index].key) { s2.push(totalValue); } } } setItems(s2) }); }// 姓名更改 const handleChangeName = (value: string[]) => { console.log(`selected ${value}`); param.name = value console.log(param) setSelectedName(value); }; // 定义重置函数 const handleResetAndQuery = () => { param = { name: [], date: '', }; setSelectedName([]); getTotalBeforeData(); };<Form.Item wrapperCol={{ offset: 6, span: 16 }}> <Button type="primary" size="large" htmlType="submit" onClick={getTotalBeforeData} > 查询 </Button> </Form.Item> </div> <div id='b2' style={{ display: "block" }} > <Form.Item wrapperCol={{ offset: 6, span: 16 }} style={{ marginLeft: "20px" }}> <Button type="primary" size="large" htmlType="submit" onClick={handleResetAndQuery} > 重置 </Button> </Form.Item>点击重置并没有重新查询并渲染
04-04
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值