在React流量中进行Ajax调用的位置
Where to make Ajax calls in React flux
我有一个react js应用程序,用户可以在其中创建一个用户,然后我向后端发布一个http。
我有一个动作看起来像这个
export function createUser(name, username, password) {
dispatcher.dispatch({
type: "CREATE_USER",
name,
username,
password,
});
}
然后在我的商店里,我调用action,它会触发一个函数,向后端发布一个http帖子,看起来像这个
handleActions(action) {
switch(action.type) {
case "CREATE_USER": {
this.createUser(action.name, action.username, action.password);
break;
}
default:
}
}
我应该在商店中调用ajax,还是在它自己的操作中调用ajax?
首先,您需要redux thunk,它可以让您有机会创建以异步方式调度其他操作的操作。
之后,您可以创建一个调用服务器的操作,并在结果分派时创建一个新的操作来存储新数据。例如:
getData(param) {
return (dispatch) => {
dispatch(dataRequestAction());
return fetch(`/data/${param}`)
.then(r => r.json())
.then(data => dispatch(setDataAction(data)))
.catch(err => dispatch(errroDuringRataRetrieving(err)))
};
}
正如您在这里看到的,您有一个操作(getData),它实际上不会更改存储,而是触发"dataRequestAction",它放入存储请求启动的数据。然后,如果请求完成,可以触发其中一个操作:
setDataAction-如果一切正常;
errroDuringRateRetrieving-如果请求失败。
通过这种方式,您可以通过redux处理ajax。
我认为我们应该有一个单独的名为api的文件夹。在那里,我们将有我们所有的api调用。我们可以注入这些文件并调用那些函数,我们将这些函数放在调用api和响应动作的函数所在的位置。
相关文章:
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- Javascript/jQuery中的并行Ajax调用
- 任何方式使AJAX调用Gmail API,而无需通过JS库
- node.js请求数据事件未在CORS ajax调用中触发
- 如何从ajax调用返回.wrap()元素
- Ajax调用在Firefox中不会自动响应
- AJAX调用中的非法调用
- 使用AJAX调用将GeoJSON数据拉入传单
- 在MVC 4中,对Controller的Ajax调用为空
- Jquery:对返回JSON数据的php脚本的Ajax调用
- 在ajax调用中阻止来自JS对象的函数
- 如何在MVC5中ajax调用的部分视图中引用外部javascript
- 页面加载后的Ajax调用
- 如何使用Ajax调用特定的控制器和操作来重定向用户
- curl和fileget_contents在ajax调用后不起作用
- 在任何AJAX调用之前触发一个javascript函数
- 无法在mvc视图中使用ajax调用获取操作返回的模型对象列表
- Ajax调用ERror Cross Origin REquest:在rails中自动完成大学列表
- ASP.NET MVC 3-在ajax调用后,重定向到新页面或生成页面刷新
- 点击功能没有'ajax调用动态元素(Backbone)后无法工作