- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
遵循快速原型(prototype)方法,我正在 Marionette.js/backbone.js 中开发一个应用程序,并大量使用窗口对象将集合和 View 绑定(bind)到全局堆栈(例如 window.app.data、window.app .views)。
当然,将对象封装在单个类中并在需要时将它们作为参数传递总是更好(更平滑!)。然而,当应用程序及其潜在用例变得非常大时,这就会有一些限制。由于我处理的数据来自 API,因此任何感兴趣的人都可以访问,这是否证明将数据存储在窗口对象中是合理的?或者 ES6(或者特别是 Marionette.js)中是否有其他最佳实践来实现相同的结果,但以更私密的方式?!
最佳答案
我已经进入details about a simple namespacing pattern in JavaScript在另一个答案中。您似乎已经通过 window.app.data
等接近了这一点。
但看来您对 JavaScript 的工作原理有很多误解。
a namespace-based solution that integrates nicely with Browserify/AMD-modules
那为什么不使用RequireJS呢?浏览器化?还是网页包?没有什么是模块化方法不能做得更好的,而全局的意大利面条式代码却能做到这一点。
such would be read-only
没有。虽然将对象属性设置为只读并非不可能,但您必须明确使用类似 Object.seal
or Object.freeze
的内容来执行此操作。 .
I do not want to attach objects to the namespace, but actual instances
JavaScript 没有“命名空间”作为语言的一部分,它只是一种将所有代码范围限制在文字对象(键值)内的模式。
你可以放任何你想要的东西。
const MyNamespace = {
MyType: Backbone.Model.extend({ /*...*/ }),
instance: new Backbone.Model(),
anyValue: "some important string",
};
理想情况下,您可以在 IIFE 中定义命名空间以避免将任何变量泄漏到全局范围。
const app = app || {};
app.MyModel = (function(app){
return Backbone.Model.extend({
// ...
});
})(app);
[...] data I deal with comes from an API and therefore would be anyway accessible to anybody interested
即使数据包含在不会泄漏到全局范围的模块中,任何人都可以访问该数据。 JavaScript 就是这样工作的,它在用户的浏览器中,他可以对代码和数据做任何他想做的事。
does that justify storing data in the window-object?
没有。
Or are there other best-practices in ES6
ES6 与您为应用程序采用的架构和模式无关。
but in a more private manner?!
正如我之前所说,JavaScript 中的隐私是不可预期的。
[encapsulate objects in a single class and pass them as parameters where needed] has some limitations when an app and its potential use-cases become really big.
这是不正确的。恰恰相反。软件模式的存在只是为了帮助减轻项目范围扩大时出现的任何限制。
您可以使用多种模式来帮助处理较大应用程序的复杂性,例如:
我没有专门读这本书,但是JavaScript Design Patterns似乎是了解更多信息的好方法,它演示了 JS 中软件模式的具体实现。
关于javascript - JS : Best practice on global "window" object,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48141299/
上下文 我有一个日间 TUMBLINGWINDOW(类似于下面所示的) SELECT DATEADD(day, -1, System.Timestamp()) AS WindowStart
因此,我正在开发一个非常小的 Web 组件,以作为更大的设计系统的一部分。 我对网络组件的使用有点陌生,但我知道这个特定的网络组件可以在一个布局中使用很多很多次。 此 Web 组件控制在传递给它的任何
我刚刚开发了一个 Android 应用程序(minSdkVersion 23/targetSdkVersion 29),可以连接到 BluetoothLE 设备以定期获取数据。 现在,在 MainAc
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
我一直在阅读有关 Airplay SDK 和 Dragonfire SDK 的内容。这些是在没有 Mac 的情况下进行 iphone 开发的合法选择吗?大家有更好的解决办法吗? 最佳答案 由于签名等原
我正在考虑使用 DTO 而不是传递我的域对象。我在这里和其他地方都读过几篇文章,我知道有几种方法可以完成这项工作。 如果我总共只有大约 10 个域类,并且考虑到我想在我的 View (WPF 前端)中
我的问题是,如果我有一个列表 list = [1,2,3,4,5,6,7] 如果我想知道这个列表中元素的数量,是len(list) 或 list.count 更好的选择?还是 .count 仅适用于来
我想知道 Django Rest Framework 的最佳实践。我一直通过每个用户使用不同的序列化程序(员工、帐户所有者、其他人)和 HTTP 方法来限制更改帐户上某些属性的访问权限,但我觉得这太不
我有数百个用于测试组件的脚本。这些脚本中的每一个都包含一组下标和单独的记录。 下标可以在多个 TC_Level 脚本中使用,甚至可以在其他下标中使用。 每个脚本都有一个唯一的名称。 例子: TC_1
我正在建立一个以两种语言提供产品信息的网站:英文和中文。 每个产品必须有英文名称,也可以有中文名称。 每次请求产品页面时,request检查对象以确定产品名称应该以英文还是中文显示。在后一种情况下,如
场景:应用程序具有可以启用某些优化的算法。默认情况下,有些是打开的,有些是关闭的。在 Java 中是否有一种方便的方法来实现某种全局属性系统? 要求: 必须很容易两次使用不同的设置运行程序的多个实例
我从事嵌入式工作,我有一些管理硬件的软件模块。这个模块有状态,状态转换很复杂:根据事件,模块可以从状态 A 到状态 B 或者可能到 C .但是,当它退出某个状态时,它应该对硬件执行一些操作,以使其也保
我有一个免费网站,可以流式传输实时股票期权数据。我想让用户制作并保存他们自己的 JavaScript 可调用工具来解释选项数据。用户可以调用这些自定义工具来帮助他们自己做出有关期权的买卖决定。 但对于
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 2 年前。 社区在 6 个
我不是 DBA,我不知道什么是最好的解决方案。我有两个表, Custumers Table CustomerId (primary key, identity) ... 和 Suppliers Tab
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 7年前关闭。 Improve t
我一直在阅读关于版本控制主题的所有问题,但我认为我没有找到一个看起来像我自己的场景。 场景是: 我们有一个中型/大型 Web 应用程序,它有(至少应该有)一个部署到所有客户端的核心。当我们向客户演示应
我希望根据继承来组织一些项目,目的是确定哪些项目是连接最密集的父项,并且还只是看到形成的连接。 通常这将通过拓扑排序来完成,但我的图有循环。是否有类似“尽力而为”拓扑排序的东西,它可以尝试根据连接数或
以下在 JQuery 中附加事件处理程序的方法有什么区别? (function () { var $body = $("body"); $('button').click(functi
我是一名优秀的程序员,十分优秀!