- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在寻找在我的 React 组件中构建状态的方法,以便我可以一起实现两个目标:(1) 在复杂的应用程序中管理浏览器历史记录,以及 (2) 让单个组件可以在外部环境中轻松重用主要应用程序。
该应用程序有一个面板组件,可让用户在我们的网站上导航和阅读内容。在主应用程序中,可以打开多个面板并将其排列在一起。在主应用程序之外,还有其他页面,我希望能够轻松地放入单个 Panel 组件。
随着这段代码的发展,每个 Panel 都有一个丰富的状态,表示它加载了什么内容和其他显示设置。这使得进入另一个页面变得容易 - 我可以只渲染一个 Panel 组件,用户可以与之交互,它会自行处理。
然而,对于浏览器历史记录,这就变得很棘手了。有一个 App 组件管理多个面板以及从历史记录中推送和弹出的状态。为了让它能够全面了解整个应用程序的状态,每个面板都会在发生更改时推送其状态的副本。当状态从历史中弹出时,App 组件可以从它呈现的每个面板传递一个 initialState。正如您所想象的,随着更新周期最终相互循环,这变得困惑且容易出错。
感觉我需要采取的方法是集中状态(按照建议 here )并尝试使每个单独的面板无状态。由于重写代码中已有的对 setState
的所有调用需要付出很大的努力,因此我正在尝试评估这是否是唯一的方法。还感觉这种方法会使在应用程序外部重用组件变得更加困难。我将不再觉得 Panel 是一个独立的组件,我可以在页面上呈现它,因为它还需要某种外部管理器来处理它的状态以及从内部改变它的所有事件。
你会推荐什么?
最佳答案
我做了一个关于 React 的应用程序并实现了 React-Router,你可以将 URL 数据传递给每个面板,知道它们处于什么状态以及加载了什么内容,例如你可以有一个像这样的 URL: http://yoururl.com/index/user/userID1/item/itemID2/filterDate?= “2014 年 9 月 19 日”
要重用您的面板,您可以创建一个 url 来创建一个分层的路由 View :您可以传递 throw 组件您想要在必须加载的渲染 View 上知道的所有内容。
我的 routerDom 示例
我建议调查 react-router。
关于javascript - 为 Reusable React Components 和 Browser history 设计状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34668840/
在 Firefox 扩展的 Javascript 中,您可以调用 gBrowser.getBrowserForTab但是没有gBrowser.getTabForBrowser .所以我写了自己的并且它
在问这个可能含糊不清的问题之前,我搜索了 SO,发现许多对“现代浏览器”的引用,但没有定义。由于这是一个被广泛使用和引用的术语,令我惊讶的是我在 Internet 上找不到定义甚至描述。 那么,在 2
更新:老问题仅适用于 IE11 预览版;浏览器模式在 IE11 最终版本中回归。但有一个问题:它几乎没有用,因为它不模拟条件注释。例如,如果您使用它们在旧版 IE 中启用 HTML5 支持,您将无法再
我的移动页面和短信有问题:链接。该页面主要由基于 Android 和 iOS 的智能手机通过 QR 扫描应用程序访问。 特别是在 iPhone 上,有一些带有集成浏览器的 QR 应用程序(webkit
我想使用 CustomTabsIntent。但是我没有找到androidx的customTabs路径和版本。 最后我得到了这个:androidx.browser:browser:1.0.0 我想知道正
我想将来自不同域(支付提供商)的 ssl 安全页面加载到 iframe 中。据我所知,一些(或全部?)浏览器会在页面的某些部分受到保护而其他部分不安全时警告用户。 这是真的吗? 如果是这样,如果主站点
在 Protractor 中,有 browser.pause() function : Beta (unstable) pause function for debugging webdriver t
我可以使用以下方法检索浏览器日志 browser.manage().logs().get('browser').then(function(browserLog) { logger.info('
当使用 protractor 时,全局变量 browser 似乎具有 browser.driver 的所有功能。 我特地问这个是因为我不确定是使用 browser.wait 还是 browser.dr
面对 Protractor 的计时问题。有时我的 Protractor 测试用例会因网络或性能问题而失败。我已经解决了 browser.sleep() 的现有问题。后来知道了browser.wait(
我仍然无法找到解决此问题的方法。我们有一个启动浏览器窗口的应用程序,但我们使用的底层第三方插件尚不支持 IE9。我知道我可以通过点击 F12 并选择它来切换到 IE8 的浏览器模式。 有没有办法在命令
在 Protractor 脚本中,我总是遇到超时问题,即使我设置了很大的 time out jasmine interval、allscripttimeout...在某些地方,我不得不等到元素出现,比
我正在运行一个 Angular 应用程序,并且在 Protractor 上测试时尝试获取当前 URL。使用哪一个? browser.driver.getCurrentUrl() 或 browser.g
“所有浏览器兼容”和“跨浏览器兼容”有什么区别? “交叉”是什么意思,是指不同的操作系统吗? 如果任何网站在 IE 7、8 FF 3+、Safari 3+ 的桌面版本上运行良好,我们可以说它是跨浏
不明白浏览器同步中的错误阅读文档,其中 gulp 4 真的没有写任何关于它的内容。在 gulp 4 的文档中也没有理解(异步)。如何解决这个问题。谢谢。 bla bla bla bla bla bla
我正在尝试在 ASP.Net C# 代码隐藏中执行“如果浏览器是 IE 且版本低于 9”。 但是,在 chrome 中,以下行: if (Request.Browser.Browser == "IE"
我第一次玩 watir,使用 this site作为指导。我在一个简单的程序(如下)中遇到错误 - 它在第一个非要求行失败,如图所示。 如果我没有运行下面显示的内容,而是删除了该行,它会打开一个空的
下面的 if 条件我认为它是说 - 如果浏览器是 IE 并且 IE 浏览器版本高于 9,但我没有 IE 9 来测试它,所以很难知道正确的输出,这也是不是 100% 的我想要的 bcos 默认情况下该脚
我通过 Pingdom 测试了我的网站并得到了这个: 我进行了搜索,但找不到解决方案。有谁知道我怎样才能得到这个14到100? 最佳答案 不是一个完整的解决方案,但您可以通过将两个请求合并为一个来改善
是否可以禁用浏览器/窗口之间的 HTML5 拖放功能? 我正在使用具有 native HTML5 拖放功能的 Angular2 应用程序,并希望防止用户将其拖动到浏览器窗口之外并防止将可拖动对象拖放到
我是一名优秀的程序员,十分优秀!