gpt4 book ai didi

javascript - 应用 className/onClick/onChange 不适用于自定义 React 组件

转载 作者:数据小太阳 更新时间:2023-10-29 03:49:05 29 4
gpt4 key购买 nike

我几乎是 React 的新手。我正在尝试创建一个简单的编辑和创建蒙版。这是代码:

import React, { Component } from 'react';
import Company from './Company';

class CompanyList extends Component {

constructor(props) {
super(props);
this.state = {
search: '',
companies: props.companies
};
}

updateSearch(event) {
this.setState({ search: event.target.value.substr(0,20) })
}

addCompany(event) {
event.preventDefault();
let nummer = this.refs.nummer.value;
let bezeichnung = this.refs.bezeichnung.value;
let id = Math.floor((Math.random()*100) + 1);
$.ajax({
type: "POST",
context:this,
dataType: "json",
async: true,
url: "../data/post/json/companies",
data: ({
_token : window.Laravel.csrfToken,
nummer: nummer,
bezeichnung : bezeichnung,
}),
success: function (data) {
id = data.Nummer;
this.setState({
companies: this.state.companies.concat({id, nummer, bezeichnung})
})
this.refs.bezeichnung.value = '';
this.refs.nummer.value = '';
}
});
}

editCompany(event) {
alert('clicked');
event.preventDefault();
this.refs.bezeichnung.value = company.Bezeichnung;
this.refs.nummer.value = company.Nummer;
}

render() {
let filteredCompanies = this.state.companies.filter(
(company) => {
return company.bezeichnung.toLowerCase().indexOf(this.state.search.toLowerCase()) !== -1;
}
);
return (
<div>
<div className="row">
<div className="col-xs-12 col-sm-12 col-md-12 col-lg-12">Suche</div>
<div className="col-xs-12 col-sm-12 col-md-9 col-lg-9">
<div className="form-group">
<input className="form-control" type="text" value={this.state.search} placeholder="Search" onChange={this.updateSearch.bind(this)} />
</div>
</div>
</div>
<form onSubmit={this.addCompany.bind(this)}>
<div className="row">
<div className="col-xs-12 col-sm-12 col-md-12 col-lg-12">Neuen Eintrag erfassen</div>
<div className="col-xs-12 col-sm-12 col-md-3 col-lg-3">
<div className="form-group">
<input className="form-control" type="text" ref="nummer" placeholder="Nummer" required />
</div>
</div>
<div className="col-xs-12 col-sm-12 col-md-3 col-lg-3">
<div className="form-group">
<input className="form-control" type="text" ref="bezeichnung" placeholder="Firmenname" required />
</div>
</div>
<div className="col-xs-12 col-sm-12 col-md-3 col-lg-3">
<div className="form-group">
<button type="submit" className="btn btn-default">Add new company</button>
</div>
</div>
</div>
</form>
<div className="row">
<div className="col-xs-10 col-sm-10 col-md-10 col-lg-10">
<ul>
{
filteredCompanies.map((company)=> {
return <Company company={company} key={company.id} onClick={this.editCompany.bind(this)} />
})
}
</ul>
</div>
</div>
</div>
);
}
}

export default CompanyList

Company 类如下所示:

import React, { Component } from 'react';

const Company = ({company}) =>
<li>
{company.Nummer} {company.Bezeichnung}
</li>


export default Company

我现在的问题是,为什么当我点击 Companyonclick 事件没有被触发。

这部分:

      <ul>
{
filteredCompanies.map((company)=> {
return <Company company={company} key={company.id} onClick={this.editCompany.bind(this)} className="Company"/>
})
}
</ul>

最佳答案

原因很简单,当你点击喜欢的时候

<Company company={company} key={company.id} onClick={this.editCompany.bind(this)} />

它不是在组件上设置的事件,而是传递给 Company 组件的 Prop ,可以像公司中的 props.company 一样访问组件,

你需要做的是在Company组件中指定onClick事件和className

import React, { Component } from 'react';

const Company = ({company, onClick, className}) => (
<li onClick={onClick} className={className}>
{company.Nummer} {company.Bezeichnung}
</li>
)

export default Company

作为 prop 传递给 Company 组件的函数可以通过任何名称传递,例如

<Company company={company} key={company.id} editCompany={this.editCompany.bind(this)} className="Company"/>

像这样使用

import React, { Component } from 'react';

const Company = ({company, editCompany}) => (
<li onClick={editCompany}>
{company.Nummer} {company.Bezeichnung}
</li>
)

关于javascript - 应用 className/onClick/onChange 不适用于自定义 React 组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44070162/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com