react+ts父子组件传值

父传子

①在父组件中定义const nameFromParent: string = "John";

②从父组件传递给子组件<ChildComponent name={nameFromParent} />

③在子组件中定义属性的类型interface ChildProps { age: number;}

④如果数据多需要解构再使用const { name,... } = props;,如果只有一个参数也可以直接卸载函数的参数括号中

⑤在子组件中使用<p>Child Component</p>

ts 复制代码
import React from 'react';

// 子组件
interface ChildProps {
  name: string;
  age: number;
  handleClick: () => void;
}

const ChildComponent: React.FC<ChildProps> = (...props) => {
  const { name, age, handleClick } = props;

  return (
    <div>
      <p>Child Component</p>
      <p>Name: {name}</p>
      <p>Age: {age}</p>
      <button onClick={handleClick}>Click me</button>
    </div>
  );
};

// 父组件
const ParentComponent: React.FC<ParentProps> = () => {
  const nameFromParent: string = "John";
  const ageFromParent: number = 25;

  const handleClick = () => {
    console.log('Button clicked!');
  };

  // 使用 {...props} 将所有属性传递给子组件
  return (
    <div>
      <p>Parent Component</p>
      <ChildComponent name={nameFromParent} age={ageFromParent} handleClick={handleClick} />
    </div>
  );
};

export default ParentComponent;

子传父

①在父组件中定义事件名称并赋予点击事件<ChildComponent sendDataToParent={handleDataFromChild} />

②在父组件中实现点击事件const handleDataFromChild = (data: string) => {};

③在子组件中定义事件类型interface ChildProps {sendDataToParent: (data: string) => void;}

④如果数据多需要解构再使用const { sendDataToParent,... } = props;,如果只有一个参数也可以直接卸载函数的参数括号中

⑤在子组件中定义点击事件并<button onClick={sendData}>Send Data to Parent</button>

⑥并在子组件中实现点击事件调通过父组件传过来的事件传递参数const sendData = () => {sendDataToParent(data); };

另外如果想不点击直接发送参数的话可以在useEffect(() => {sendDataToParent(data);},[sendDataToParent])

ts 复制代码
import React from 'react';

// 子组件
interface ChildProps {
  sendDataToParent: (data: string) => void;
}

const ChildComponent: React.FC<ChildProps> = ({ sendDataToParent }) => {
  const sendData = () => {
    const data = "Data from Child";
    // 在需要的时候调用回调函数传递信息给父组件
    sendDataToParent(data);
  };

  return (
    <div>
      <p>Child Component</p>
      <button onClick={sendData}>Send Data to Parent</button>
    </div>
  );
};


// 父组件
const ParentComponent: React.FC<ParentProps> = () => {
    
  const handleDataFromChild = (data: string) => {
    console.log('Data received from Child:', data);
    // 在这里处理从子组件接收到的数据
  };

  return (
    <div>
      <p>Parent Component</p>
      {/* 将回调函数传递给子组件 */}
      <ChildComponent sendDataToParent={handleDataFromChild} />
    </div>
  );
};

export default ParentComponent;
相关推荐
Jonathan Star1 天前
沉浸式雨天海岸:用A-Frame打造WebXR互动场景
前端·javascript
工业甲酰苯胺1 天前
实现 json path 来评估函数式解析器的损耗
java·前端·json
老前端的功夫1 天前
Web应用的永生之术:PWA落地与实践深度指南
java·开发语言·前端·javascript·css·node.js
LilySesy1 天前
ABAP+WHERE字段长度不一致报错解决
java·前端·javascript·bug·sap·abap·alv
Wang's Blog1 天前
前端FAQ: Vue 3 与 Vue 2 相⽐有哪些重要的改进?
前端·javascript·vue.js
再希1 天前
React+Tailwind CSS+Shadcn UI
前端·react.js·ui
用户47949283569151 天前
JavaScript 的 NaN !== NaN 之谜:从 CPU 指令到 IEEE 754 标准的完整解密
前端·javascript
群联云防护小杜1 天前
国产化环境下 Web 应用如何满足等保 2.0?从 Nginx 配置到 AI 防护实战
运维·前端·nginx
醉方休1 天前
Web3.js 全面解析
前端·javascript·electron
前端开发爱好者1 天前
前端新玩具:Vike 发布!
前端·javascript