位置: 编程技术 - 正文

简述AngularJS相关的一些编程思想(angularjs常用总结)

编辑:rootadmin

推荐整理分享简述AngularJS相关的一些编程思想(angularjs常用总结),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:angularjs2,angularjs常用总结,angularjs2,angular jsx,angularjs web application development cookbook,angularjs web application development cookbook,angular jsx,angularjs常用总结,内容如对您有帮助,希望把文章链接给更多的朋友!

在过去的几个月里,我一直遨游于Angular的世界。如今回想起来,很难想象在没有类似于Angular.js, Backbone.js以及其伙伴Underscore.js这些数据绑定框架下我每天如何去编写一个大型前端应用。我不敢相信我已经用它们完成了那件工作。

可能我有点小偏见,但考虑到我一直在做的应用是在浏览器中实现Photoshop类型的编辑器,它呈现相同的数据有几种完全不一样的方式。

图层以图形化的形式呈现,占据了屏幕的大部份。它们列于一个面板内,你可以删除它们。 当你选中一个图层时,它的边缘会被虚线包围,同时会高亮显示于列表中。 类似地,图层在面板中的尺寸和它们的大小这些属性取决于画布。 我上面提到过的面板是可以拖拽,折叠,关闭的。

如果不是一个像Augular的框架,这一种类的互动、数据连接和视图同步很容易变成一个持续的噩梦。有能力修正一个地方的模型和用Augular修正所有相关的视图听起来几乎像在骗人。添加、消除或者改动一个层次只是一个改变对象的问题。层次,x+=,完成。并没有地方需要手动作废视图、手工地修改在DOM的层次中的每一个实例,甚至是因为这个问题而去与DOM互动。

Augular使我们可以去到我们从未想过的地方,像设置一串使我们能够在现有的环境下做出申请的键盘捷径。举个例子,文件编辑捷径(像&#;B:用于切换黑体文本)只是使我们能够编辑一个文件层面。

同样地,我们为这些快捷键附加了一个描述(通过一个我们创建的服务进行注册),然后我们可以显示一个快捷键的列表,同时还有它们的描述,在一个便利条上。此外,我们写了一个指令使得我们可以将单独的DOM元素与它们的快捷键绑定在一起,当你的鼠标在元素上停留一会,会出现一个提示,让你知道此时可用的快捷键。

Angular可以使我们做到我们做梦也想不到的事情。

老实说,这就好像我们已经不是在编写一个web应用。web只是媒介。当我们增进了我们对Angular的理解后,代码变得更加模块化,更加独立,并且更加连接交互。它很自然地变得更加Angular了。

然后通过Augular,我的意思是在Augular背后的那些高度互动的丰富的应用开发哲学。javascript,一个让我们能够开发那些一段时间前我们还觉得不可能的一部分软件的相似的东西。

我们甚至有能力去开发一个成熟的用于修改DOM变成历史中现在选中的点的历史控制板,并让它工作得很好。至少可以这么说,当你兴奋的返回历史控制板查看那些与Augular能力相关的数据在你的视图工作中完美的更新每一个微小的细节。

那并不总是容易的,基本代码总是变成一场无可控制的混乱。

的确,在过去几周里我们一直在更新并且将我们的前端整个架构重写。在我们开始重新编写以前,看一下自从0..6以来,将Angular更新得有优势的过程。如果看了变更日志,你就知道这是一个相当长的过程。

在这个重构的过程里,我们从以错误的方法对待Angular,转变为以Angular的方式对待Angular。

在我们的案例中,错误的方法包含了许多的问题,我们不得不在此时,在使我们的代码基础到达可爱状态之前,解决它们。

在全局作用域声明控制器(Controllers)

这是一个 Angular 初学者容易做的例子。如果你熟悉 Angular,你也会熟悉这种模式。

这段代码没有包含在闭包中,或者说,所有的声明都在根作用域,全局的 window 对象上,混蛋啊。用正宗的 Angular 方式来写的话是使用它提供的模块 api ( module API)。但是如你所见,即使是文档和建议步骤任然过时地建议你使用全局作用域:

这样做,极棒的事情将出现。

-- Angular.js文档

使用模块(modules)允许我们以下面的方式重写控制器(controllers):

我发现使用 Angular 控制器的漂亮做法是你必须在所有地方使用控制器方法(controller function),因为你需要控器的依赖注入,而且控制器提供了新的作用域,绑定我们从需求到封装我们所有的脚本文件成为自调用函数表达式( self-invoking function expressions),像这样 (function(){})()。

依赖$injection在最早的例子中你可能已经注意到了, 依赖是使用$inject注入的. 另一方面,大部份的模块API, 允许你传入一个函数作为参数, 或者一个包含了依赖的数组作为参数, 其后面跟着一个依赖于这些依赖的函数. 这是在Angular中我不喜欢的一点 , 但这应该是它文档的过错. 在文档中的大部份例子认为你并不需要一个数组形式的参数; 但现实是,你是需要的。 如果你在使用一个压缩器压缩你的代码之前, 没有运行ngmin , 事情将会变得糟糕.

由于你没有使用数组格式['$scope',...]明确声明你的依赖包,你看上去简洁的方法参数将会被缩略成类似于b,c,d,e的样子,有效地扼杀了Angular的依赖注入能力。我认为他们构建框架的思路存在了重大的失误,这与我在非常不喜欢 Require.js 和他们麻烦的 AMD 模块最后的推论是相似的。

简述AngularJS相关的一些编程思想(angularjs常用总结)

如果他不能在产品中使用,它还有什么用?

我的这种态度是因为你在产品中所使用的框架里,有一部分代码是已经写死了的。这对于开发中经常用到、产品中偶尔用到的实用工具,诸如控制台和错误报告,是很好的。如果语法上的甜头(可读性)只用在开发中,就会变得没有任何意义。

这些破事让我很愤怒, 现在发泄完了. 谈谈$符吧...

减少 jQuery扩散

深入的讲, 这个应用是 "类Angular程序", 也就是说它只是包裹于Angular之中, 大多数DOM 交互是经由jQuery处理的, 这给Angular带来相当多的争论。

如果今天我要从头开始写一款Angular.js应用,我不会立即包含进jQuery。我会强迫自己使用 angular.element 来代替。

如果jQuery存在的话,angular.element这个API将包装它,同时它给Angular团队实现 jQuery的API提供了可以替代的选择,名为jqLite。这并不是说 jQuery不好,或者说我们需要另一个某种实现,来映射它们的API。只是因为使用jQuery显得不是那么有Angular的思想。

让我们来看一个具体的,愚蠢的,例子。在controller被声明的地方,它使用jQuery来做元素之上的类操作。

然而,我们可以用我们期望的方法来使用Angular,替代之。

最后一行你不能直接,或者通过jQuery来操作DOM(改变属性,增添事件监听器)。你应该使用指令来替代。那篇文章很棒,去读读看。

如果你仍然jQuery化了,有许多文章可以一读,例如这篇迁移指南,还有我的关于怎样使用jQuery的批判性思考 这篇文章。

我不是要声明我们准备完全移除 jQuery 。我们有其他更重要的目标,例如,发布我们的产品。这个时候,删除 jQuery 的依赖还是很有意义的。这样做能够使我们的控制器得到简化,我们创建处理 DOM 的指令,使用 angular.element 即使它实际上映射着 jQuery 。

我们依赖着有点恶心的 jQuery UI,我们当然不只是为了它的对话框而使用它,它还有很多用途。例如,拖动一个列表项然后把它放到一个已排序的列表中,如果不使用 jQuery UI,这将牵涉到一大堆代码。因此,实际上,对于 jQuery UI 来说,并没有真正很好的替代品。拖拽的功能可以通过一个轻量级的拖拽库 angular-dragon-drop 来替代,但是,对于元素排序插件,还是得依赖 jQuery UI 。

管理代码库

还有一个我们在迁移中需要解决的问题是整个代码库都挤在一个单一的大文件中。这个文件包含了所有控制器、所有服务、所有指令以及每个控制器的特定代码。我指出一点使得我们可以准确地把每个文件只包含一个组件。目前,我们有很少的文件,却包含了不知一个组件。大多数是因为一个指令使用一个服务来与外界共享数据。

尽管和 Angular 无关,我们还是把我们的 CSS 样式表(stylesheet)模块化。我们为每个组件中使用的 CSS 类名前面都加上了两个字的前缀。例如, .pn- 作为前缀,代表面板(panel); .ly- 前缀,代表着图层(layer)等等。这样做的直接好处就是,你不需要再费劲地想哪个组件的 CSS 类是怎样的了。因为你已经为它们设置了命名空间,你就很少会重复用到某一个 CSS 类名了。另一个好处就是减少了嵌套,我们以前曾经用 #layoutEditor div.layer .handle div 这样复杂的选择器表达式,而现在,我们只需要 .ly-handle-content 就可以了。深度的嵌套现在只发生在额外的选择器覆盖上,例如 .foobar[disabled]:hover,或者,最坏的情况下,像 .foo-bar .br-baz 。

下面是一些我们定下的 CSS 类命名规则:

用两个字符来描述组件名:.ly-、.dd-、.dg-等等 采用 .ly-foo-barname 来代替嵌套命名 .ly-foo .bar 避免内联样式,总是使用 CSS 类名。这能够减少不界面的一致性,提高语义解释能力 不要在 CSS 中使用 ID 来赋值

在实现了这套面向组件的 CSS 声明方法后,我又想了很久“the class soup way”。

Angular 强制你写好的代码,但是更深一层说,它强制你去思考。一会儿后,它就像一个服务器端的实现,或者成为一个不堪忍受的“黑客大会”。这些都取决于你这么选择。

接近完美

让我们来解析一下我们应用程序的各部件的其中之一,层。

这里,我们使用了cv-layer类,也就是说这个元素是canvas组件的一部分(canvas指的使我们绘制层的地方,不要和HTML5canvas混淆)。然后,我们 在foreach类似的循环里面 使用ngRepeat标签来为每一个层的建立一个相似的元素。并且通过一个我们所写的反向的filter来传递,所以,最后一个层位于最上部,而且对用户可见。apLayer标签,其实是为了绘制层的任务所采用的,不论是一个图片,或者是某些文字,HTML,或别的东西。event标签(ng-mousedown, ng-mouseup, ng-dblclick) 仅仅是简单的为事件做代理而用,这些事件将被我们的层选择服务来处理。最后,ngHide这个标签,我想就不必多言了吧。

这么一大堆功能(译者注:有点夸张了),而Angular成功的使它看上去如此简单,用可读的HTML,从某种程度上就告诉了你它们是怎么回事。更多的是,它使得你可以分解开不同的需要考虑的问题,从而你能够写出来简洁的代码,不需要一次把所有的事情都考虑在内。简而言之,它降低了复杂度(译者注:其实Angular本身就很复杂,呵呵),让复杂变的简单。而让“难以简单度量的问题”,变的可能。

我期待不久会有更多关于Angular代码的文章。特别是,我乐于探讨一些在升级我的代码的时候,所遇到的一些边缘的案例,如何解决其中的问题,同时让其余的部分同样工作。

在JavaScript的AngularJS库中进行单元测试的方法 开发者们都一致认为单元测试在开发项目中十分有好处。它们帮助你保证代码的质量,从而确保更稳定的研发,即使需要重构时也更有信心。测试驱动

对JavaScript的全文搜索实现相关度评分的功能的方法 全文搜索,与机器学习领域其他大多数问题不同,是一个Web程序员在日常工作中经常遇到的问题。客户可能要求你在某个地方提供一个搜索框,然后你

JavaScript中的Promise使用详解 许多的语言,为了将异步模式处理得更像平常的顺序,都包含一种有趣的方案库,它们被称之为promises,deferreds,或者futures。JavaScript的promises,可以促

标签: angularjs常用总结

本文链接地址:https://www.jiuchutong.com/biancheng/380452.html 转载请保留说明!

上一篇:使用Raygun来自动追踪AngularJS中的异常

下一篇:在JavaScript的AngularJS库中进行单元测试的方法(在javascript中)

  • 已抵扣进项税转出是在哪个属期
  • 小规模纳税人代扣代缴个人所得税
  • 水利基金的计税税率6
  • 个税申报怎样作废
  • 增值税加计扣除账务处理
  • 装修费用摊销是当月还是次月
  • 企业收到的政府补贴交所得税吗
  • 黑盘报税流程视频教程
  • 资产减值损失结转到哪个科目
  • 新会计准则科目编码
  • 工伤医疗费用个人社保卡支付找谁报销
  • 固定资产报废如何做账务处理
  • 收到去年所得税汇算清缴退税账务处理
  • 出口退税是退进项
  • 企业向银行贷款需要什么条件
  • 个人所得税期末余额在借方表示
  • 应扣缴税额是什么意思
  • 出纳可以做记账表格吗
  • 成品油发票应该怎么冲红?
  • 债务重组过程
  • 发票丢失罚款标准要看金额吗
  • 租房合同开发票的金额要和合同一致吗
  • 季度不超过30万免税分录
  • 如何理解总分机的概念
  • 什么是补提或者计提
  • 佣金可以开票吗
  • 电脑网页密码不正确
  • Windows10如何解压rar
  • 无效发票不能报销怎么办
  • 鸿蒙系统怎么快速充电
  • php数组函数实现机选双色球
  • 什么是递延所得税费用
  • 初学者如何
  • windows update更新错误
  • 转让股权怎么做会计分录
  • php axios
  • 哪些情况需要做进项税转出
  • vue项目页面写在哪里
  • PHP:proc_get_status()的用法_命令行函数
  • 分析卡拉哈迪沙漠的形成原因
  • 附加税申报错误,已缴费,怎么办
  • 黑白相间表带
  • 对公账户的银行卡号是几位数
  • php使用正则表达式检测是否包含非数字
  • 隐藏php后缀
  • 员工福利费会计分录 最新
  • 工厂院里栽什么树好呢
  • 最常用的成本核算表格
  • 可供分配利润的会计分录
  • 工程施工科目借方尾差怎么调整
  • 一般户可以付款吗
  • 个人捐赠支出税前扣除条件
  • 固定资产盘亏造成的损失计入什么科目
  • 回收锯末木屑价格
  • 固定资产包括哪些东西
  • 物业服务企业管理
  • mysql爆破字典
  • 应用程序发生异常如何解决
  • 2003怎么创建用户
  • mac chrome浏览器插件
  • freebsd11.3安装教程
  • linux管理器
  • 怎么禁止电脑qq自动启动
  • cocos 2d x
  • cocos2d开发的知名游戏
  • unity制作ar手机游戏
  • android 自定义
  • android:ListView的局部刷新
  • 如何改变this指向
  • webpack vue-loader
  • 利用js脚本模拟鼠标点击事件
  • 使用粗盐热敷十大危害
  • shell编程教程
  • unity做app
  • Android调用jni获取mac地址
  • 江苏税务登录密码是几位
  • 海珠税务局许丰
  • 吉林省会考成绩查询入口网站官网
  • 地税局与税务局的区别
  • 从租计征房产税怎么申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设