- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习中间件,想确认一些事情。如果我有以下中间件设置:
dispatch -> thunk -> promise 中间件 -> 流量中间件 -> reducer
我想澄清一些其他的事情。如果我对以下内容的理解不正确,请告诉我:
如果我分派(dispatch)函数或 promise 以外的任何东西,操作将直接转到 reducer。
如果我派发一个函数,它会通过 thunk,如果我调用 next,它会通过 promise 中间件。
我的中间件.js
import * as actions from '../actions/actionCreators'
import { formatPokemonData, formatDescription, formatPokeType } from '../helpers/helpers'
import fetch from 'isomorphic-fetch'
export const promiseErrorMiddleware = store => next => action => {
if (!action.promise) {
return next(action)
}
const url = action.url
const fetchName = action.fetchName
return Promise.resolve(fetch(url)).then((response) => {
if (response.status === 404) {
store.dispatch({type: 'SPELLING_ERROR'})
throw new Error("Please ensure Pokemon name is spelled correctly")
} else if (response.status >= 400) {
store.dispatch({type: 'SERVER_ERROR'})
throw new Error("Server Error")
}
return response.json()
}).then((data) => {
next({data: data, needDirection: true, fetchName: fetchName })
})
}
export const dataTrafficMiddleware = store => next => action => {
if (!action.needDirection) {
return next(action)
}
const data = action.data
const fetchName = action.fetchName
if (fetchName === 'fetchPokemon') {
next(actions.receivePokemon(formatPokemonData(data)))
store.dispatch(actions.fetchPokemonDescription(data.name))
} else if (fetchName === 'fetchPokemonDescription') {
store.dispatch(actions.receivePokemonDescription(formatDescription(data)))
store.dispatch(actions.addActivePokemon(store.getState().pokemonArray.filter((p) => (
p.name === data.name
))[0]))
store.dispatch(actions.checkPokeTypeCache(store.getState().activePokemon.pokeType))
} else if (fetchName === 'mainTypeFetch') {
store.dispatch(actions.receivePokeType(formatPokeType(data)))
store.dispatch(actions.addActivePokeType(formatPokeType(data)))
} else if (fetchName === 'subTypeFetch') {
store.dispatch(actions.receivePokeType(formatPokeType(data)))
store.dispatch(actions.addActiveSubPokeType(formatPokeType(data)))
}
}
最佳答案
- If I dispatch anything other a function, or promise, the action will go directly to the reducer.
- If I dispatch a function, it will go through thunk, and out of that function, if I call next, it will go through the promise middleware.
这两点你是对的。
- If I dispatch a function, it will go through thunk, and out of that function, if I dispatch another function, it will go through thunk again
redux-thunk
在函数中注入(inject) dispatch
,它从链的开始再次启动进程。所以,如果你要派发一个函数,它将再次由 thunk
处理。
- If I'm in the traffic middleware, calling next would take the action to the reducer, or if I called dispatch and the action is neither a function nor promise, it will also go directly to the reducer.
很难回答你的问题,因为我不知道你的流量中间件实现
- If in thunk, promise middleware, or traffic middleware, I don't use dispatch or next, then the returned object is cut off and the cycle stops there and data will no longer go through any of the middleware chain nor to the reducer.
是的,如果您不调用next
,链中的其他中间件将不会得到您的操作,也不会有任何影响。
关于javascript - dispatch、next 和中间件的排序在 react redux 中是如何工作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39523769/
有人可以给我一个更简单的以下代码的解决方案(它正在展开给定结构 0xFC :: len :: payload :: ... :: 0x0A :: 0x0D 的整数列表): object Payload
我已经在我的网站上安装了 SSL 证书,但 intermediate.crt 无法正常工作。任何 SSL 检查器(例如 GeoTrust Checker)都告诉我,缺少中间 key 。网站上已经使用了
如何让图像从这个框的中间开始? (中间纵横) 最佳答案 有几种方法可以做到这一点,如果它需要在所有浏览器(IE7+ 和其他浏览器)中工作,你需要做不同的事情来让它在某些情况下工作。 使用绝对位置
如何强制 min-height 和 vertical-align:middle 为 td 元素或其内部元素工作? 最佳答案 td 元素上的 height 等同于 min-height,因为如果需要,表
我正在尝试自动滚动到订单簿的中间行。 我有 orderBook div,其中放置了带有 orderBook 的表。该表的其中一行有一个 id middleRow。我想做的是滚动该行并将其放置在 ord
我正在尝试在 javascript 中计算绝对定位元素的 transform-origin 属性,以便它们在悬停时填充整个视口(viewport)。 我尝试通过 x 除以窗口宽度和 y 除以窗口高度来
我有休闲字符串 ' this is my string ' 是否可以删除开头和结尾的所有空格,只在单词之间留一个空格。 要选择我使用过的所有空间: SELECT regexp_replace('
我正在设法创建我的第一个复杂的 J2E 解决方案,并且在每个教程中我都发现了某种中间表的用法,如下所示: 表:用户、用户角色、角色虽然逻辑会简单地向用户表添加一个键来引用它在角色表上的角色,但为什么要
我正在寻找以下解决方案。我想定位一个图像元素,例如 在中间。所以高度是视口(viewport)的高度,宽度会自动设置,图像的中间应该在视口(viewport)宽度的中间。 我搜索的一个例子就像下面的网
我正在设计一种布局,它更像是注册用户的个人仪表板。我让它变得简单,使用基本的 2 列网格,一个用于侧边栏,一个用于主要内容。 因为,例如,80% 的网站使用将发生在一个单独的子系统中,在无 chrom
我有三个不同的 div 标签(不在彼此内部)和代码,所以它有一个把单词放在左边、中间或右边,但中心非常偏离中心。这是 HTML 代码: .desc { float: right; color:
我有以下CSS http://jsbin.com/azivip/75/edit我想让黄色的 div 高度填充蓝色和绿色 div 之间的空间。使用高度继承似乎使 div 超出了绿色 div。 有什么想法
我不得不在其父元素的中间放置一些文本。我用下面的代码实现了它: #div1 { position: relative; margin: 0; padding: 0; } #div2 {
发现一个使用合法证书(由thawte 签名)的网站,但所有浏览器都会拒绝它。我不明白为什么。thawte 的支持告诉我一个域有两个证书,然后将这个 https://www.sslshopper[dot
我正在尝试使用 OpenSSL 创建证书链,但出于某种原因,当我在我的计算机上安装我的根 CA 并尝试验证证书链时,它总是告诉我它找不到证书的颁发者.为了让事情发生,我必须安装中间 CA,这是没有意义
我看到 REST 的一大好处是依赖 HTTP 缓存。我不是在争论这个,而是完全认同这个想法。但是,我从来没有看到对中间 HTTP 缓存的更深入的解释。 如果我将 Cache-control heade
查看此图片 Facebook Messenger Android App Buttons ( MESSENGER\ACTIVE ) 我怎样才能做到这一点? 详细信息:- 带有 2px 红色边框的 di
我的任务是制作漂亮的文本,在文本中间加一条白线,如下图所示。是否可以使用 css 来实现?这是 Fiddle .container{ height:200px; width:400px;
在拉丁文字中,字母有大写和小写形式。在 Python 中,如果你想比较两个字符串而不考虑它们的大小写,你可以使用 'string'.upper() 或 'string'.lower() 将它们转换为相
我正在使用 awk 对文件进行一些文本处理。例如删除尾随空格。 awk '{gsub(/ +$/, "")} {print $0}' filename 这很好用。但是当我将输出重定向到原始文件时。它变
我是一名优秀的程序员,十分优秀!