栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

React js onClick无法将值传递给方法

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

React js onClick无法将值传递给方法

简单的方法

使用箭头功能:

return (  <th value={column} onClick={() => this.handleSort(column)}>{column}</th>);

这将创建一个新的函数,

handleSort
以正确的参数进行调用。

更好的方法

将其提取到子组件中。在render调用中使用箭头函数的问题是,每次都会创建一个新函数,最终导致不必要的重新渲染。

如果创建子组件,则可以传递处理程序并将props用作参数,然后仅当props更改时才重新渲染(因为现在处理程序引用不再更改):

子组件

class TableHeader extends Component {  handleClick = () => {    this.props.onHeaderClick(this.props.value);  }  render() {    return (      <th onClick={this.handleClick}>        {this.props.column}      </th>    );  }}

主要成分

{this.props.defaultColumns.map((column) => (  <TableHeader    value={column}    onHeaderClick={this.handleSort}  />))}

旧的简便方法(ES5)

使用

.bind
通过所需要的参数:

return (  <th value={column} onClick={that.handleSort.bind(that, column)}>{column}</th>);


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/464522.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号