Truyền tham số và gọi hàm giữa các component

Truyền tham số và gọi hàm giữa các component làm rõ hơn cách thực cơ bản về truyền tham số và gọi hàm giữa các component trong React,

Trong React bạn có thể tạo nhiều component. Trong một component có thể nhúng các component con vào, rồi trong component con có thể nhúng các component con  nữa. Trong toàn ứng dụng bạn sẽ có thể có một “cây” comoponent nhiều tầng,

Vậy việc truyền props từ cha vào component con , hay gọi hàm từ comnponent con đến cha sẽ thực hiện thế nào?  Ghi nhớ các  nguyên tắc sau:

1. Cha khi render component con , có thể truyền prop cho nó, giá trị tham số có thể là string, number, array hoặc 1 funtions

2. Con khi muốn dùng props là biến từ cha truyền xuống thì theo công thức {props.tênbiến} hoặc {this.props.tên biến} – nếu dùng trong class component.

3. Trong component con, khi muốn gọi 1 hàm của component cha thì : compponent cha khi render con phải truyền props cho con. Con sẽ gọi khi có sự kiện theo cách sau (ví dụ)

– Ở cha:       

<ComCon aa = {this.xuly} / >

– Trong component con:    

<button onClick={ ()=>this.props.aa()  }> ABC </button

Ngữ cảnh 1

Giả sử có ngữ cảnh thế này: Trang index.js nhúng component MM. Component MM lại nhúng component NN. Comnonent NN lại nhúng PP

index.js

Trang index nhúng và render component MM, truyền cho MM 2 prop, cái là tham số có tên title giá trị là 1 chuỗi, 1 cái có tên là xuly tham chiếu đến function xuly trong index

import React from 'react';
import ReactDOM from 'react-dom';
import MM from './MM'

function xuly(v){
  console.log("Hàm xử lý trong index.js")
}
ReactDOM.render(
    <MM xuly={xuly} title="Title for MM" />,
  document.getElementById('root')
);

MM.js

import React from 'react';
import NN from './NN';
class MM extends React.Component{
    xuly(v){ console.log("Hàm xử lý trong MM. V= " + v);}
    render(){
        return(
        <div> 
        <h2>{this.props.title} </h2>               
        <button type="button" onClick={()=>this.xuly('mm')}>Nút xuly (MM) </button>
        <button type="button" onClick={ () => this.props.xuly(5)} >
            Nút gọi hàm cha trong index.js
        </button>
        <NN xuly={this.xuly} title="Title for NN"/>
        </div>
        )
    }
}
export default  MM;

NN.js

import React from 'react';
export default class NN extends React.Component{
    xuly(v){  console.log("Hàm xử lý trong NN. V= " + v); }
    render(){
        return(
        <div> 
         <h3>{this.props.title} </h3>
          <button type="button" onClick={()=> this.xuly(3)}>Nút xuly (NN)</button>
          <button onClick={() => this.props.xuly(5)}>
              Nút gọi hàm cha
           </button>
        </div>
        )
    }
}

Quan sát hoạt động

Nhắp nút và xem kết quả trong console

Trường hợp gọi hàm qua nhiều cấp

Trường hợp nhắp button trong NN (cháu nội) , mà muốn chạy tới hàm trong index (ông nội) thì sao?

Hàm trong cháu nội gọi tới 1 hàm trong cha, rồi hàm trong cha sẽ gọi tới hàm trong cha nữa. Ví dụ sửa lại hàm trong MM để được như sau:

    xuly = (v) => { 
        console.log("Hàm xử lý trong MM. V= " + v);
        this.props.xuly(6);
    }

(đổi xuly trong MM thành hàm dạng  arrow function để dùng this)

Bạn xử lý tương tự nếu trong NN có nhúng thêm component PP vào

Ngữ cảnh 2:

Component A có 2 component con là BB và CC. Vậy khi CC muốn truyền state qua cho BB  thì sao? Trong CC, gọi tới hàm cha trong AA, trong AA sẽ thực hiện render lại BB.

index.js

import React from 'react';
import ReactDOM from 'react-dom';
import AA from './AA'

function xuly(v){
  console.log("Hàm xử lý trong index.js")
}
ReactDOM.render(
    <AA xuly={xuly} title="Title for AA" />,
    document.getElementById('root')
);

BB.js

import React from 'react';
export default class BB extends React.Component{
render(){
    return(
    <div> <h3>{this.props.title} </h3> 
          <p>n trong BB = {this.props.n}</p>
          <button onClick={() => this.props.xuly(5)}>
            Gọi cha từ BB
          </button>
    </div>
    )
}
}

CC.js

import React from 'react';
export default  class CC extends React.Component{
render(){
    return(
    <div> <h3>{this.props.title}</h3>       
          <p>n trong CC = {this.props.n} </p>
          <button onClick={() => this.props.xuly(6)}>
                Gọi cha từ CC
          </button>
    </div>
    )
}
}

AA.js

import React from 'react';
import ReactDOM from 'react-dom';
import BB from './BB';
import CC from './CC';
export default  class AA extends React.Component{
    tinhtoanB(v){  alert("Hàm tinhtoanB trong AA. v = " + v) }
    tinhtoanC(v){
        ReactDOM.render(
            <BB xuly={this.tinhtoanB} title="Title of B" n={v} />,
            document.getElementById("comBB")
        )
        alert("Hàm tinhtoanC trong AA. v = " + v)
    }
    render(){
        return(
            <div> 
                <h2>{this.props.title} </h2>
                <div id="comBB">
                    <BB xuly={this.tinhtoanB} title="Title of B" n="1"/>
                </div>
                <hr/>
                <div id="comCC">
                    <CC xuly={this.tinhtoanC} title="Title for C" n="2"/>
                </div>
            </div>
        )
    }
}

Bài viết giúp bạn rỗ cách thực cơ bản về truyền tham số và gọi hàm giữa các component trong React, còn cách khác nữa sẽ giải quyết sau nhé. Các bài học liên quan trước cần đọc qua đó là Component trong ReactVòng đời của component trong React