react——实现父子组件的传值

需求:当页面中存在一个收藏图片,初始状态是未收藏,点击后显示收藏状态,于此同时父组件存在一个按钮,按钮的状态会跟随子组件中收藏未收藏的状态的改变而改变。同时实现取消收藏的效果。

效果:

 

 父组件:

import React, { useRef, useState } from "react";
import Son from "./son";

const Father = () => {
    const [parentData, setParentData] = useState<String>("未收藏");

    const getChildData = (val: String) => {
        setParentData(val);
    };

    return (
        <div className="home-wrap">
            <button >{parentData}</button>
            <Son getCollection={getChildData} />
        </div>
    );
};


export default Father;

子组件:

import React, { useState } from 'react';
import before from "../img/a.png";
import after from "../img/b.png"
const Son = (props: any) => {

    const { getCollection } = props;
    const [collection, setCollection] = useState<String>("未收藏");

    const handleClick = (val: String) => {
        setCollection(val);
        getCollection(val);
    };
    return (
        <div className="child-wrap">
            <div >
                {
                    collection === "未收藏" ? (
                        <div onClick={() => handleClick("已收藏")}><img style={{ width: "50px" }} src={before} /></div>
                    ) : collection === "已收藏" ? (
                        <div onClick={() => handleClick("未收藏")}>
                            <div onClick={() => handleClick("未收藏")}><img style={{ width: "50px" }} src={after} /></div>
                        </div>
                    ) : collection === "未收藏" ? (
                        <div onClick={() => handleClick("已收藏")}><img style={{ width: "50px" }} src={before} /></div>
                    ) : null
                }

            </div>
        </div>
    );
};

export default Son;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值