当前位置: 首页 > news >正文

为网站添加isapi扩展公司个人怎么制作网站

为网站添加isapi扩展,公司个人怎么制作网站,做承兑 汇票一般会用哪些网站,地方农产品网站建设async thunk 解决 API 调用的依赖问题 一句话节省看下面一堆内容的时间就是: async thunk 中可以使用 async/await 锁住其他的 action 操作 一般 API 之间存在三种情况: A 和 B 之间没有依赖关系 这样的情况下,A 和 B 可以各调用各的&#x…

async thunk 解决 API 调用的依赖问题

一句话节省看下面一堆内容的时间就是:

async thunk 中可以使用 async/await 锁住其他的 action 操作

一般 API 之间存在三种情况:

  1. A 和 B 之间没有依赖关系

    这样的情况下,A 和 B 可以各调用各的,哪块数据拉完就先渲染哪块

  2. B 依附于 A 进行调用

    比如说有些数据只有用户登录后才能获取

  3. A 和 B 必须同时完成调用

    这个就没什么好多说的

第一点和第二点就算是原生的 Redux,处理起来虽然稍微有些的麻烦,不过实现起来相对而言也比较简单。第三点使用原生的 Redux 处理起来就比较麻烦,以前实现的方式大致如下:

// in action file
// ...
function fetchSomeData() {// call api to store datareturn dispatch => {batch(() => {dispatch(fetchData1());dispatch(fetchData2());dispatch(fetchData3());// ..some more dispatches...});}
}
...// in react component
dataLoaded(){// ....retrieve all the data from different places...if (!data1)    return false;if (!data2)    return false;// ...check all the data...return true;
}// ...
render() {if (this.dataLoaded()) {return actual_content;} else {return loading_content;}
}
// ...

之前想,如果可以这样调用的话就方便了:

function fetchSomeData() {// call api to store datareturn dispatch => {Promise.all([dispatch(fetchData1());dispatch(fetchData2());dispatch(fetchData3());// ...some more dispatches...]).then(() => dispatch(setLoading(false)));}
}

可惜当时的 batch 还不支持这个操作,因此大多数情况下借用第三方的工具,如 Redux Saga 之类的实现这种功能会比较方便。不过从 Redux Toolkit 之后,就可以比较方便的使用 Promise.all 进行实现了。

大致的实现方法如下:

  • userSlice

    import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';
    import axios from 'axios';export const userSlice = createSlice({name: 'user',initialState: {data: [],isLoading: false,error: null,},extraReducers(builder) {builder.addCase(fetchUsers.pending, (state, action) => {state.isLoading = true;});builder.addCase(fetchUsers.fulfilled, (state, action) => {state.isLoading = false;state.data = action.payload;});builder.addCase(fetchUsers.rejected, (state, action) => {state.isLoading = false;state.error = action.error;});},
    });export const fetchUsers = createAsyncThunk('users/fetch', async () => {const response = await axios.get('https://jsonplaceholder.typicode.com/users');console.log(new Date());return response.data;
    });export const usersReducer = userSlice.reducer;
    
  • postSlice

    // similar configuration as user
    function later(delay) {return new Promise(function (resolve) {setTimeout(resolve, delay);});
    }export const fetchPosts = createAsyncThunk('posts/fetch', async () => {await later(5000);const response = await axios.get('https://jsonplaceholder.typicode.com/posts');console.log(new Date());return response.data;
    });
    
  • 另一个调用这两个 slice 的 thunk

    // similar configuration as previous
    export const fetchHome = createAsyncThunk('home/fetch',async (_, thunkAPI) => {const res = await Promise.all([thunkAPI.dispatch(fetchUsers()),thunkAPI.dispatch(fetchPosts()),]);console.log(res);return [];}
    );
    

在组建中就可以直接调用 fetchHome,实现结果如下:

在这里插入图片描述

http://www.yayakq.cn/news/405004/

相关文章:

  • 用ps做招生网站成都网站建设哪家好文章
  • 地产公司网站建设计划书济南高端网站设计建设
  • 华为网站建设方案模板php网站开发毕业设计
  • 淘宝网站都是怎么做的吗动漫制作专业有本科吗
  • 网站seo批量查询工具市场调研模板
  • 外国产品设计网站成都网站公司网站建设
  • crm客户管理系统模块刷移动端seo软件
  • 怎么知道网站被百度k了简单的网站开发流程
  • 网站的程序怎么做沈阳优化推广哪家好
  • 江门制作公司网站东莞千寻电子科技有限公司
  • 哈尔滨手机网站建设价格低it外包项目做完了就解散了吗
  • 有什么做服装的网站怎么在搜狐快站上做网站
  • 个人网站的制作方法wordpress通用页面模板下载
  • 网站建设与制作教学计划thinkphp怎么做网站
  • 网站开发图片编辑汕头网站制作找谁
  • 北京网站建设要多少钱百度推广管理平台登录
  • 聊城高端网站建设报价网站 pr
  • zencart网站建设wordpress网站后台
  • 服务器搭建网站云网站功能
  • 郑州建网站哪个公司好wordpress 301
  • 你们需要网站建设那个网站可教做课件好
  • 公司网站设计公司网站建设和邮箱的关联
  • tag 网站托管公司企业服务公司排名
  • 宜宾市网站建设做质粒图谱的网站
  • 内容型网站有哪些彩票网站开发 合法
  • 比较好的外贸网站织梦cms零基础做网站
  • 呼伦贝尔做网站学校网站建设的建议
  • 下载建设网站阿里云虚拟主机wordpress
  • 一个网站可以有几个域名四川专业网站建设
  • 太原市0元网站建设百度推广助手app下载