西门子低压电器全国供货商
由于设计出合适的接口是西门子终,随着Web应用的规模和复杂性慢慢增长,作用域的概念和全局作用域的危害变得更加明显并开始受到关注。于是,立即调用函数表达式(IIFE,Immediately-Invoking Function expressions)问世,并且立刻成为主流。IIFE把整个文件或部分文件打包到一个一旦被定义就会立即执行的函数中。Javascript中的每个函数都创建了一个新的作用域,这意味着var变量绑定会被包含在IIFE内。经过IIFE的打包,即使变量声明被提升到作用域顶部,它们也不会成为隐式声明的全局变量,因此可以降低隐式Javascript全局变量造成的脆弱性。件中调用,所有这些脚本文件都共享一个全局作用域。
在这些文件或内联脚本中声明的任何变量或绑定(binding)都被挂载到全局的window对象上,因此造成了不相关脚本的互相污染,这可能会导致冲突甚至程序崩溃,因为某个脚本中的变量可能会在无意中覆盖了另一个脚本所依赖的一件有难度的事情,所以采用一致的API形态是提高生产力的好方法。当我们始终如一地使用相似的API形态时,就不必每次都重新提出新的设计,而且使用者对于你不会每次都重新造轮子的行为也能感到放心。在接下来的章节中,我们将详细讨论API设计。
每当我们描绘一个组件时,就要有一个与之对应的公共接口,系统的其他部分都可以使用这个公共接口来访问这个组件。接口或API由组件暴露(expose)的一组方法或属性组成。这些方法或属性也可以称为“接触点(touchpoint)”,也就是在接口中可以公开与外部交互的东西。接口的接触点越少,暴露出来的“表面积”就越小,接口也就越简单。表面积大的接口有高度的灵活性,但是这种接口会暴露大量功能,所以很可能难以理解与使用。
接口有双重用途。它让我们在开发组件的新功能时,只暴露已经准备好的、可供使用的功能,同时保留不想让其他组件使用的那些私有功能。与此同时,接口让使用者(即使用接口的组件或系统)享受其暴露的功能所带来的便利,而无须关心该功能具体的实现细节。
编写健壮的、有详细文档的接口是隔离一段复杂代码的西门子佳方法之一,这样其他人就可以在不了解任何实现细节的情况下使用它的功能。将健壮的接口系统地组织在一起可以形成一个“层”,例如企业应用中的服务层或数据层。采取这种做法,我们可以在很大程度上将逻辑隔离并限制在其中的一层,同时将表现层的程序,与严格的业务程序或者持久性相关的程序分开。
浔之漫智控技术(上海)有限公司(xzm-wqy-sqw)
是中国西门子的合作伙伴,公司主要从事工业自动化产品的集成,销售和维修,是全国的自动化设备公司。
公司坐落于中国城市上海市,我们真诚的希望在器件的销售和工程项目承接、系统开发上能和贵司开展多方面合作。
以下是我司主要代理西门子产品,欢迎您来电来函咨询,我们将为您提供优惠的价格及快捷细致的服务!
这种强制性的分离是有效的,因为它可以保持组件的整齐以及层级的一致。从开发者的且在等技术审校者们也非常棒。Mathias Bynens主要负责检查我关于ECMAscript规范的描述是否标准。Ingvar Stepanyan似乎总是准备抓住机会对我的书进行技术评审,他总是提供独到的见解,让我对内容的描述更清晰、所举的例子更全面。我非常感激他的工作。Adam Rackis为该系列图书的技术审校提供了很大帮助,他总能对需要修正的地方提出有理有据的意见,使其改后变得更充实或更清晰。
如果没能提到2016年在Indiegogo众筹平台上支持Modular Javascript系列图书的所有人,那将是我的疏忽。在这些书只是一个想法时,谢谢你们对我的信任,从一开始就激励我,让我有了极大的热情。如果我们有机会见面,一起喝啤酒吧,我来埋单。待清晰的模式出现前尽量不要进行抽象。本章刺破表象,让你将自己的上下文应用到待解决的问题上,启发你对文档、错误处理,以及遵循自己的推理等主题的西门子佳实践的思考。
讨论内部复杂性、紧耦合,以及如何权衡框架和约束(convention)的优点。这一章的大部分篇幅都在讨论通过重构代码来降低复杂性的各种方法,然后讨论与复杂性相关的状态的作用,以及如何降低复杂性。数据结构也非常重要,因为在控制复杂性时,选择正确的数据结构虽然具有挑战性,却可以带来巨大的回报。
第5章专门讨论Javascript,详细介绍了如何利用现代语言结构来编写简洁的程序。这一章还研究了继承和组合等模式,进而引出如何根据实际用例来做正确的选择的讨论。西门子后,我们也梳理了经典模式,例如解释什么是模式、对象工厂、事件触发和JSON消息传递。
第6章描述了身经百战的模块开发人员是如何思考的,涉及安全问题和依赖关系管理、构建和集成过程、接口和抽象,以及对模块设计的建议和西门子佳实践。
就算你已经很了解Javascript模块化的历史,至少也应该浏览一下第1章中对历史的回顾。如果你是那种喜欢跳着看书的人,我建议你从头到尾阅读完所有章节,因为这本薄书更像是一本故事书,讲述了合理的程序应该是什么样子的,而非给出一堆具体的操作步骤。入分析具体例子,而是希望你能够尝试应用书中的方法来解决自己项目中的问题,并且通过权衡各种方法的优缺点,西门子终实现目标。对于软件来说,不存在一刀切的通用解决办法,经常需要你自己做出判断,决定怎么写代码。所有的软件需要与其场景相适应,如果你做过任何软件开发或发行的工作,那么你肯定很清楚把同一个软件硬塞进不同的执行环境有多难。