如何将 prop 从子组件传递到父组件?

How can I pass a prop from the child component to a parent component?

提问人:oyerohabib 提问时间:11/18/2023 最后编辑:isherwoodoyerohabib 更新时间:11/18/2023 访问量:30

问:

我有一个更新服务器状态模态组件,该组件正在服务器.js组件中使用。我正在尝试将 prop 从 updateServerStatusModal 组件传递到 servers 组件,但在经过几次不同的尝试后,它似乎无法正常工作。

updateServerStatusModal 组件

...other imports
import Select from './Select'

const UpdateServerStatusModal = ({
    open,
    setOpen,
    title = '',
    confirmBtnTitle = 'Delete',
    variant = 'alert',
    onConfirm,
    icon = 'exclamation',
    onStatusChange,
}) => {

    const handleConfirm = async event => {
        await onConfirm(selectedStatus)
    }

    const statusList = [
        { id: 1, label: 'active' },
        { id: 2, label: 'full' },
        { id: 3, label: 'inactive' },
    ]
    const [selectedStatus, setSelectedStatus] = useState(statusList[0].label)

    return (
        <Modal open={!!open} setOpen={setOpen} width={464}>
            <Modal.Title>
                {icons[icon]}
                <span>{title}</span>
            </Modal.Title>
            <Select
                idKey="id"
                labelKey="label"
                value={selectedStatus}
                placeholder="Select type"
                onChange={label => {
                    setSelectedStatus(label)
                    if (onStatusChange) {
                        onStatusChange(label)
                    }
                }}
                list={statusList}
            />

            <div>
                <Button
                    onClick={handleConfirm}
                >
                    confirmBtnTitle
                </Button>
            </div>
        </Modal>
    )
}

export default UpdateServerStatusModal

服务器组件

import { useEffect, useState } from 'react'
import axios from '@/lib/axios'
import Dropdown from '@/components/Dropdown'
import UpdateServerStatusModal from '@/components/updateServerStatusModal'

const Servers = () => {
    const [servers, setServers] = useState(null)
    const [selectedStatus, setSelectedStatus] = useState('')

    const handleUpdateStatus = server => {
        handleModalOpen(true, {
            title: 'Update Server Status',
            text: <span>Are you sure you want to update server status</span>,
            confirmText: 'Update Status',
            type: 'info',
            onConfirm: async () => {
                try {
                    await axios.put(`/api/servers/${server?.uuid}`, {
                        status: selectedStatus,
                    })
                }
            },
        })
    }

    return (
            <UpdateServerStatusModal
                open={modalProps?.open}
                setOpen={handleModalOpen}
                title={modalProps?.title}
                description={modalProps?.text}
                confirmBtnTitle={modalProps?.confirmText}
                variant={modalProps?.type}
                onConfirm={modalProps?.onConfirm}
                onStatusChange={newStatus => setSelectedStatus(newStatus)}
            />
    )
}

export default Servers
reactjs react-props 反应状态

评论

0赞 David 11/18/2023
您的代码在哪些方面未按预期工作?请详细说明您观察到的具体问题以及您所做的调试。要了解有关此社区的更多信息以及我们如何为您提供帮助,请从导览开始并阅读如何提问及其链接资源。
2赞 isherwood 11/18/2023
数据下降,事件上升。你不会向外传递道具。请修改以更清楚地了解什么是“道具”以及您试图将它传递到哪里。

答:

1赞 Aryan kholqi 11/18/2023 #1

我认为您可以使用回调函数将 props 从子组件传递到父组件。

父组件:

import React, { useState } from 'react';
import ChildComponent from './ChildComponent';

const ParentComponent = () => {
  const [dataFromChild, setDataFromChild] = useState();

  const getDataFromChildHandler = (data) => {
    setDataFromChild(data);
  };

  return (
      <ChildComponent onDataFromChild={getDataFromChildHandler} />
  );
};

export default ParentComponent;

子组件:

import React from 'react';

const ChildComponent = ({ onDataFromChild }) => {

  const sendDataToParentHandler = () => {
    const data = "data from child component";

    onDataFromChild(data);
  };

  return (
    <>
      <button onClick={sendDataToParentHandler}>Send To Parent</button>
    </>
  );
};

export default ChildComponent;