gpt4 book ai didi

reactjs - Eslint 提示 this.props.handleSubmit 在 prop 验证中丢失

转载 作者:行者123 更新时间:2023-12-02 08:05:08 24 4
gpt4 key购买 nike

我有一个名为 SiteTechnologyForm 的组件

class SiteTechnologyForm extends React.Component {

static propTypes = {
name: PropTypes.string,
site_technology_id_number: PropTypes.string,
common_site: PropTypes.string,
title: PropTypes.string,
errors: PropTypes.string
}

constructor(props) {
super(props);

this.state = {
logged_in: localStorage.getItem('token') ? true : false,
name: props.name || '',
site_technology_id_number: props.site_technology_id_number || '',
common_site: props.common_site || '',
};

this.handleChange = this.handleChange.bind(this);
this.handleSubmit = this.handleSubmit.bind(this);
}

UNSAFE_componentWillMount() {
if (!this.state.logged_in) {
browserHistory.push("/accounts/login");
}
}

handleChange(event) {
if (event.target && event.target.name){
this.setState({[event.target.name]: event.target.value});
}
}

handleSubmit() {
let payload = {
"common_site": this.state.common_site,
"name": this.state.name,
"site_technology_id_number": this.state.site_technology_id_number
};
this.props.handleSubmit(payload)
}

render() {
const {
title,
errors
} = this.props;

return !this.state.logged_in ? '' :
<BaseForm title={title} handleSubmit={this.handleSubmit} errors={errors} data={this.state}>
<CommonSiteAutocomplete
label="CommonSite *"
id="id_common_site"
required={true}
inputProps={{
name: "common_site",
onChange: this.handleChange,
value: this.state.common_site,
required: true
}}
/>
<CustomInput
labelText="Name *"
id="id_name"
formControlProps={{
fullWidth: true
}}
inputProps={{
type: "text",
onChange: this.handleChange,
name: "name",
value: this.state.name,
required: true
}}
/>
<CustomInput
labelText="Site Technology ID *"
id="id_site_technology_id_number"
formControlProps={{
fullWidth: true
}}
inputProps={{
type: "text",
onChange: this.handleChange,
name: "site_technology_id_number",
value: this.state.site_technology_id_number,
required: true
}}
/>
</BaseForm>
}
}

ESlint 提示 props 验证中缺少 handleSubmit

SiteTechnologyForm 用于其他组件,例如下面的 AddSiteTechnology:

class AddSiteTechnology extends React.Component {

constructor(props) {
super(props);

this.state = {
errors: ''
};

this.handleSubmit = this.handleSubmit.bind(this);
}

handleSubmit(data) {

fetch(siteTechUrl, {
headers: {
'Content-Type': 'application/json',
Authorization: `Token ${localStorage.getItem('token')}`
},
method: 'POST',
body: JSON.stringify(data),
})
.then(response => {
if (response.status >= 400) {
return this.setState({errors: response.statusText});
}
browserHistory.push("/site_technologies/list");
})
}

render() {
return <SiteTechnologyForm title="Add Site Technology" handleSubmit={this.handleSubmit} errors={this.state.errors}/>
}
}

我最初尝试使用

handleSubmit: PropTypes.function

但是当我尝试运行该网页时,我在控制台中收到此错误

checkPropTypes.js:19 警告: Prop 类型失败:SiteTechnologyForm: Prop 类型 handleSubmit 无效;它必须是一个函数,通常来自 prop-types 包,但接收到 undefined

如何解决 handleSubmit 未通过验证的情况?

最佳答案

根据 ESLINT,您还需要为 handleSubmit Prop 提供 Prop 类型。函数类型由 func 而不是 function 处理:

handleSubmit: PropTypes.func

关于reactjs - Eslint 提示 this.props.handleSubmit 在 prop 验证中丢失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52473264/

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