Làm cách nào để liên kết các phương thức hoặc event handler trong lệnh callback
JSX?
Làm cách nào để liên kết các phương thức hoặc event handler trong lệnh callback
JSX?
Trong React, việc liên kết các phương thức hoặc event handler trong lệnh callback
JSX là quan trọng để đảm bảo rằng this
trong phương thức đó tham chiếu đúng đến instance của component. Dưới đây là một số cách để liên kết các phương thức hoặc event handler:
Arrow functions không có context this
riêng, nên khi bạn sử dụng chúng trong JSX, this
sẽ tham chiếu đến context bên ngoài - thường là instance của component. Điều này giúp tránh việc phải liên kết this
một cách rõ ràng.
class MyComponent extends React.Component {
myMethod() {
console.log(this); // Tham chiếu đúng đến instance của MyComponent
}
render() {
return <button onClick={() => this.myMethod()}>Click me</button>;
}
}
.bind()
trong JSXBạn có thể sử dụng phương thức .bind()
để rõ ràng liên kết this
với phương thức hoặc event handler khi truyền nó vào JSX. Tuy nhiên, cách này có thể gây ra việc tạo ra một hàm mới mỗi lần component render, ảnh hưởng đến hiệu suất.
class MyComponent extends React.Component {
myMethod() {
console.log(this); // Tham chiếu đúng đến instance của MyComponent
}
render() {
return <button onClick={this.myMethod.bind(this)}>Click me</button>;
}
}
middle
Chưa có bình luận nào