- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
伙计们。我正在研究 ract+mobx+firebase 应用程序。我想将我的应用程序逻辑分离到 3 个商店:
因此,要从 db 接收 currentUser 数据,我首先需要从 fb.auth() 获取 currentUser.uid。我的 AuthStore 看起来像这样:
class AuthStore {
@observable auth = {
authUser : null,
authError : null
};
constructor () {
console.log ( 'start auth' );
this.unwatchAuth = Fb.auth.onAuthStateChanged ( user => {
console.log ( 'status changed' );
this.auth.authUser = user;
} );
}
@computed
get currentUser () {
console.log ( 'updated' );
return this.auth.authUser;
}
}
const authStore = new AuthStore ();
export { authStore };
我的UserStore:
class CurrentUser {
@observable user = ( {} );
constructor () {
this.userRef = Fb.dbRoot.ref ( `users/${user.uid}` );
this.userRef.on ( 'value', ( snapshot ) => {
this.user = snapshot.val ();
} );
} );
}
}
const user = new CurrentUser ();
export { user };
我将我所有的商店导入到一个全局商店
import { authStore } from './AuthStore';
import { user } from './CurrentUser'
import { editor } from './EditorStore'
const store = {
authStore,
user,
editor
};
window.store = store;
export { store };
然后在他们需要的地方导入这个store。
现在我有一些问题:
如果需要,我如何在 userStore.user
构造函数中设置我的 userStore
从 authStore 收到 currentUser.uid
?我 ve tried to import **authStore** to **userStore** and versa, but it didn
t 帮助,因为两个观察者(authStatusChange 和 userRef.on('value') 必须放在存储构造函数中(我说的对吗?)。因为我在开始时创建了一个 storeClass 的实例——它们在 auth.currentUser
之前实例化,得到了服务器的肯定响应。我通过在两个商店中插入 authStatusChange watcher 解决了这个问题,但我认为这不是好的解决方案
在我的应用程序中,某些组件只有在 userStore.user 存在时才能显示,如果我不设置 user @observable – 我可以通过 if(user)…
检查,但是因为他的 observable if(user)
返回 true——因为他的返回 observable 对象。我如何检查用户是否已经设置?
数据库中的用户有字段 - project。 Project 是深度嵌套的对象,我用它来描述用户项目结构并在前面显示。当用户进入编辑器时——编辑器组件将这个项目分割成 block 。每个 block 都有他的样式属性,用户可以编辑。所以当用户选择某个 block 时,这个 block 被写入 editorStore 作为 currentBlock 可观察对象,通过使用 @action setCurrentBlock,并作为参数接收对所选 block 的引用。
类 EditorStore { @observable currentBlock = null;
constructor () {
}
@computed
get blockStyles () {
return this.currentBlock.style
}
@action
setCurrentBlock ( block ) {
this.currentBlock = block
}
@action
updateBlockStyle ( data ) {
const { styleProp, value } = data;
this.currentBlock.style[ styleProp ] = value;
}
const editor = new EditorStore();导出 { 编辑器 };
所以我的 editStylesPanel 组件显示来自 @computed blockStyles 的当前 block 样式值。一切都很好,但是当我通过 @action updateBlockStyle 更改某些样式属性时——他只更新了 editorStore.currentBlock 的样式,并没有更改相关 block 中的样式user.project。我确信如果我发送一个对该对象的引用——因为 t editorStore 中的任何更改都必须发生在根对象上。为什么这没有发生?
<Provider store={…stores}>
和 @inject(‘store’)
或者通过 import {store} from ‘./store/store’
谢谢你的帮助;)
最佳答案
这是我在相同情况下所做的:
// src/stores/index.js
import {RouterStore} from 'mobx-router5';
import AuthStore from './AuthStore';
const stores = {};
const routerStore = new RouterStore(stores); // Provide access to other stores
const authStore = new AuthStore(stores);
stores.routerStore = routerStore;
stores.authStore = authStore;
export default stores;
// src/stores/AuthStore.js
export default class AuthStore {
...
constructor(stores) {this.stores = stores}; // Keep stores reference for later
...
}
虽然可行,但我希望有更好的解决方案。也许this one .
关于javascript - MobX,以及商店之间的连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44451327/
我对 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 版)添加到我的应用程序中。 我希望有一些东西处于根状态(如果可能的话),然后我的每个功能都有单独的状态。我从根状态开始
我是一名优秀的程序员,十分优秀!