- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我刚刚开始使用 Flux(现在使用 redux),并且想知道应该如何处理关系。
例如,我们可以使用 Trello,它的看板和包含卡片的列。
一种方法是为板提供一个存储/ reducer ,并将所有数据存储在其中,但这意味着一些存储非常庞大,因为它们还必须包含列和卡的所有操作。
我见过的另一种方法是将嵌套资源分离到例如 BoardStore、ColumnStore 和 CardStore 中,并使用它们的 id 作为引用。
这是一个让我有点困惑的示例:您可以有一个名为 addCard 的操作创建器,它向服务器发出请求以创建包含所有数据的卡片。如果您正在进行乐观更新,您之前会在您的商店之一创建一个卡片对象,但在您返回请求之前您无法知道它的 ID。
简而言之:
有没有推荐的方法来处理这种情况?嵌套存储/ reducer 对我来说有点傻,但否则你最终会得到非常复杂的存储,所以它看起来确实是一个妥协。
最佳答案
是的,像关系数据库一样跨多个商店使用 id 是正确的方法。
在您的示例中,假设您希望乐观地将一张新卡放入特定列中,并且一张卡只能位于一列中(一列对应多张卡)。
CardStore 中的卡片可能如下所示:
_cards: {
'CARD_1': {
id: 'CARD_1',
columnID: 'COLUMN_3',
title: 'Go to sleep',
text: 'Be healthy and go to sleep on time.',
},
'CARD_2': {
id: 'CARD_2',
columnID: 'COLUMN_3',
title: 'Eat green vegetables',
text: 'They taste better with onions.',
},
}
请注意,我可以通过 id 引用卡片,也可以在对象中检索 id。这使我能够拥有像 getCard(id)
这样的方法,并且还能够检索 View 层中特定卡片的 id。因此,我可以调用一个方法 deleteCard(id)
来响应操作,因为我知道 View 中的 id。
在卡片存储中,您将拥有 getCardsByColumn(columnID)
,这将是卡片对象上的简单映射,这将生成一个可用于呈现内容的卡片数组列的。
关于乐观更新的机制,以及 ids 的使用如何影响它:
您可以使用在同一闭包中建立的客户端 ID 来处理 XHR 响应,并在响应成功返回时清除客户端 ID,或者在错误时回滚。闭包允许您保留客户端 ID,直到响应返回。
许多人会创建一个 WebAPIUtils 模块,其中包含与保留客户端 ID 和请求/响应的闭包相关的所有方法。 Action 创建者(或商店)可以调用此WebAPIUtils模块来发起请求。
所以你有三个行动:
为了响应发起请求的操作,您的商店会收到客户端 ID 并创建记录。
为了响应成功/错误,您的商店再次接收客户端 ID,并将记录修改为具有真实 ID 的已确认记录,或者回滚记录。您还希望围绕该错误创建良好的用户体验,例如让您的用户重试。
示例代码:
// Within MyAppActions
cardAdded: function(columnID, title, text) {
var clientID = this.createUUID();
MyDispatcher.dispatch({
type: MyAppActions.types.CARD_ADDED,
id: clientID,
columnID: columnID,
title: title,
text: text,
});
WebAPIUtils.getRequestFunction(clientID, "http://example.com", {
columnID: columnID,
title: title,
text: text,
})();
},
// Within WebAPIUtils
getRequestFunction: function(clientID, uri, data) {
var xhrOptions = {
uri: uri,
data: data,
success: function(response) {
MyAppActions.requestSucceeded(clientID, response);
},
error: function(error) {
MyAppActions.requestErrored(clientID, error);
},
};
return function() {
post(xhrOptions);
};
},
// Within CardStore
switch (action.type) {
case MyAppActions.types.CARD_ADDED:
this._cards[action.id] = {
id: action.id,
title: action.title,
text: action.text,
columnID: action.columnID,
});
this._emitChange();
break;
case MyAppActions.types.REQUEST_SUCCEEDED:
var tempCard = this._cards[action.clientID];
this._cards[action.id] = {
id: action.id,
columnID: tempCard.columnID,
title: tempCard.title,
text: tempCard.text,
});
delete this._cards[action.clientID];
break;
case MyAppActions.types.REQUEST_ERRORED:
// ...
}
请不要太关注名称的细节和此实现的细节(可能存在拼写错误或其他错误)。这只是解释该模式的示例代码。
关于reactjs - 如何处理 Flux 商店中的一对多关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31641466/
我对 React 真的很陌生,需要问。 我可以有一个 ReactJs Redux store在库中,然后在也有 Redux 商店的应用程序中使用该库? 他们俩都这样做: ..A
我有两个商店版本的 Magento 安装:商店 A 和商店 B。当您转到“mydomain.com”时,我收到以下错误消息: 'There was no Home CMS page configure
我有一个按钮,单击该按钮时,将使用提供的 url 创建一个 JSONstore。然后将商店加载到网格中。如果再次单击该按钮,它会再次添加所有信息(因此会列出两次)。我想要这样,当用户单击按钮时,它会清
已结束。 这个问题是 off-topic .它目前不接受答案。 想要改进这个问题? Update the question所以它是on-topic堆栈溢出。 关闭 9 年前。 Improve this
我在 main.js 中进行 session API 调用,并将响应中的值用作我的根存储的初始值。在 vuex 中,它是这样处理的, DataService.getSession() .then(
我正尝试在 Svelte 商店中维护实时股票报价,以便屏幕上的出价和要价实时更新。我不确定商店的结构如何来保持数据的 react 性和效率。数据来自 websocket,如下所示: {'symbol'
将 Magento 商店从企业版 1.10.1.1 降级到社区版 1.7.0.0 应遵循什么程序? 我做的步骤是: 备份 Magento EE 1.10.1.1 数据库 :) 将此数据库导入到一个名为
我试图在过去 2 天使用内部应用程序共享上传我的应用程序,但无论我做什么,我都无法让它工作。这就是我所做的: 在控制台中,我点击了应用 -> 发布 -> 内部应用共享 我上传了 apk 我将自己添加到
现在的情况: 我有一个实时系统并且运行良好。 我没有测试系统。 我们的实时系统是一个多商店,在一个网站上有多个商店 View 。 问题: 我需要再添加一个 storeview 并在该 livesyst
我正在建立一个拥有零售店和批发商商店的网站。每个产品中的产品都不同,因此不仅仅是针对用户类型调整定价的问题。我需要保护批发部分的密码,以便它只对登录用户可用。我正在使用一个模块来实现这一点,但它只适用
我在应用商店上有几个应用程序,我每天都会检查所有可用的国家/地区,看看是否有人对我的应用程序留下了评论以及它在付费评级最高的位置中处于什么位置。 花时间看 iTunes 变得非常无聊。但我得到的信息非
我正在从 appsettings.json 加载配置文件,其中保存了 api url。 我已经建立了带有效果的ngrx 7商店。我在 app.component.ts onInit 中调度 loadc
我正在尝试为 Angular ngrx 存储架构中的操作编写 reducer : 这是我的 reducer : export const registration = (state: any, {ty
我创建了一个 Windows 商店应用程序,并使用 Visual Studio IDE 将其与商店相关联。在 Visual Studio IDE 中有用于创建应用程序包和上传应用程序包的菜单选项。 我
我有这个代码可以过滤我的商店 onLicenseGridSelect: function(rowmodel, record, index, eOpts) { Ext.getStore('Lic
我已将应用程序发布到 Play 商店。问题是我的应用程序的标题是 XXX YYY,但是当我输入 XXX YYY 时,搜索列表/索引中没有应用程序,但是如果我输入 XXXYYY,我可以找到我的应用程序。
我需要将所有翻译从主存储导出到另一个。 最佳答案 导出数据库中core_translate 表的内容。您可以为此使用 phpmyadmin。 关于php - 如何将内联翻译导出到另一个 Magento
我正在尝试将某些组件 (USERS) 连接到我的商店。我将向您展示每个步骤。 首先我在 index.js 中创建我的商店: // composeWithDevTools helps to follow
我不久前问过这个问题,并大致了解了商店的用途以及为什么使用它的基本解释。 但是,我目前正在为我的公司开发一个网络应用程序,并且遇到了一些计算问题。 首先,我有大约 35 个数据变量。一次只使用其中的几
我是 ngrx 的新手,我只是想了解它,让它工作起来。 我已将 ngrx(8.3 版)添加到我的应用程序中。 我希望有一些东西处于根状态(如果可能的话),然后我的每个功能都有单独的状态。我从根状态开始
我是一名优秀的程序员,十分优秀!