私たちはプロジェクトに取り組んでおり、ビジネス、ユーザー、組織としてさまざまな役割を担っています。そのために、ロールごとに異なるタブを用意しています。
組織のリストをバインドする各タブをクリックしている間、現在、各ファイルで組織のリストを取得するコードを繰り返していましたが、これはベスト プラクティスではありません。したがって、より堅牢にするコンテキスト API を使用して、単一のコード ファイルを使用して、組織のリストを取得します。
すべてが正常に機能しますが、リストから組織を削除した後、小道具を設定できません。コードは次のとおりです。
context.js
import React from 'react';
export const {Provider, Consumer} = React.createContext({})
List.js
import React, { Component } from "react";
import { Consumer } from '../../components/context';
export default class List extends Component {
state = {
organizations: [],
};
deleteOrganization(id) {
var self = this;
OrganizationService.deleteOrganization(id)
.then(function(response) {
if (response.status === 200) {
self.handleDeleteSuccessResponse(response);
} else {
console.log(response.data.errors)
}
})
.catch(function(error) {
console.log(error.response.data.errors)
});
}
handleDeleteSuccessResponse(response) {
var self = this;
const organizations = self.state.organizations.filter(
organization => organization.id !== self.state.alert.objectId
);
if (organizations.length === 0) {
this.getOrganizations();
}
this.props.context.updateValue(organizations); //seems like props not getting here
self.setState({
organizations: organizations
});
}
render() {
const { organizations} = this.state;
const { match } = this.props;
return (
<div className="welcome-wrap">
<h3 className="text-center">Organizations</h3>
<hr />
<Consumer>
{(context) => (
<Component
{ ...this.props }
context={context}
/>,
console.log(context),
<table className="table table-bordered">
<thead>
<tr>
<th scope="col">Name</th>
</tr>
</thead>
<tbody>
{context.value.organizations.map(organization => (
<tr key={organization.id}>
<td>{organization.name}</td>
<td>
<a
className="delete-btn"
onClick={event => this.deleteOrganization(organization.id)}
>
Delete
</a>
</td>
</tr>
))}
</tbody>
</table>
)
}
</Consumer>
</div>
);
}
}
ユーザー.js
import React, { Component } from "react";
import { Provider } from './../context';
// Import helper
import {
currentLoggedInUser,
} from "../../components/Helper";
// import service
import { OrganizationService } from "../../services/Index";
export default class User extends Component {
constructor() {
super()
this.state = {
actions: {
getOrganizations: this.getOrganizations,
updateValue: this.updateValue
},
organizations: []
};
};
componentWillMount(){
var id = currentLoggedInUser().belongs.id;
this.getOrganizations(id);
}
getOrganizations(id) {
var self = this;
OrganizationService.getOrganizations(id)
.then(function(response) {
var data = response.data;
self.setState({ organizations: data.data });
})
.catch(function(error) {
console.log(error.response);
});
}
updateValue = (val) => {
this.setState({organizations: val});
}
render() {
const { match } = this.props;
return (
<Provider value={{ value: this.state, updateValue: this.updateValue}} >
<List />
</Provider>
);
}
}
すべての組織を表示するコンテキストを作成し、user.js で定義<Provider>
し、list.js でアクセスします。<Consumer>
現在、いくつかの組織を削除し、DB から削除されていますが、リストは更新されず、削除されたレコードが消えるページを更新すると、古い値が表示されます。
現在、更新された組織をコンテキストで送信したいのですが、小道具を取得していません。
this.props.context.updateValue(organizations);
コンテキストを取得するための小道具を設定するにはどうすればよいですか?
Consumer から Provider 状態への更新に直面しています。