最新发布《数智时代的AI人才粮仓模型解读白皮书(2024版)》,立即领取! 了解详情
写点什么

解析 Angular 7 的十大特性

  • 2018-12-03
  • 本文字数:2823 字

    阅读完需:约 9 分钟

解析Angular 7的十大特性

Angular 是最流行的 Web 应用程序开发框架之一。随着 Angular 7 的发布,它为 Web 开发人员带来了更多功能,包括核心框架、Angular Material、与主要版本保持同步的 CLI 和工具链,并且还有了几个主要合作伙伴。


我们将在本文中介绍 Angular 团队发布的一些新功能。Angular 7 主要关注 Ivy 项目,重写 Angular 编译器和运行时代码,让它变得更小、更好、更快,但 Ivy 尚未准备好迎接它的黄金时刻。


接下来让我们来看看 Angular 7.0 引入的 10 大功能。


1.CLI Prompts

Angular CLI 已经更新到 v7.0.2,添加了一些新功能,比如现在它会在用户输入常用命令(如 ng-add 或 ng-new)时提示用户,@angular/material 可用于发现内置功能,如路由或 SCSS 支持。使用 Angular 7 创建新项目时,会默认利用 CLI 中的 Bundle 预算。

2.应用程序性能

Angular 团队发现 Angular 开发人员会在生产环境中包含反射元数据 polyfill,但这个 polyfill 只是在开发环境中用到,为了解决这个问题,v7 的部分更新将自动从 polyfills.ts 文件中将其移除,然后将它作为 JIT 模式下构建应用程序时的一个构建步骤,默认情况下在为生产环境生成构建时删除这个 polyfill。


为了提升性能,新的应用程序将在初始捆绑包超过 2MB 时发出警告,并在达到 5MB 时报错,用户可以在 angular.json 文件中修改这些预算值。


3. Angular Material 和 CDK

Angular Material 和 Component Dev Kit(CDK),Angular 7 在 Material Design 方面进行了视觉上的改进,在 2018 年获得了重大更新,带来了虚拟滚动,用于动态加载和卸载 DOM 的部分元素,以构建高性能的大型数据列表。此外,通过导入 DragDropModule 或 ScrollingModule,应用程序可以具备拖放功能。

4. 虚拟滚动


虚拟滚动包<cdk-virtual-scroll-viewport>为对滚动事件做出反应的指令提供了一些辅助。虚拟滚动可以基于可见部分加载和卸载 DOM 的部分元素。它让容器元素的高度与要渲染的元素总数的高度保持一致,从而能够高效地模拟正在渲染的所有项目,然后只在视图中渲染可见项目,为大型可滚动列表提供了非常快速的用户体验。

5.拖放


@angular/cdk/drag-drop 模块为你提供了一种通过声明性方式创建拖放界面的方法,可以支持自由拖动、在列表中进行排序、在列表之间转移项目、动画、触摸设备、自定义拖动句柄、预览和占位符,以及重新排序列表(moveItemInArray)和在列表之间传输项目(transferArrayItem)。

6. Angular 兼容性编译器(ngcc)

这个编译器用于将使用 ngc 编译的 node_modules 转换为与新 Ivy 渲染器兼容的 node_modules。Angular 兼容性编译器将使用 ngc 编译的 node_moduls 转换为类似于使用 ngtsc 编译的 node_modules。通过这种转换,Ivy 渲染引擎就可以使用一些“遗留”包。

7. Angular Do-Bootstrap

它用于引导需要引导组件的模块。Angular 7 增加了一个新的生命周期钩子(ngDoBootstrap)和接口(DoBootstrap)。


例如:


更好的错误处理

Angular 7 为 @Output 带来了一个改进的错误处理,比如对于未初始化的属性。

8. Angular 7 中的依赖项更新

TypeScript 3.1 支持

Angular 7 已将 TypeScript 版本从 2.7 升级到最新版本 3.1。在使用 Angular 7 时,必须使用 TypeScript 的最新版本。Angular 使用的 TypeScript 版本通常会滞后一些,所以这一次就匹配了最新的 TypeScript 版本。

RxJS 6.3

Angular 7 添加了最新版本的 RxJs(6.3.3),带来了一些令人兴奋的补充和变更。这些变更带来了性能提升,并且让开发人员更易于调试调用栈,并改进了模块化,同时尽可能向后兼容。

添加对 Node v10 的支持

Angular 7 团队现在也支持 Node V10,具有向后兼容性。

带有 Slot 的 Angular 元素

Angular 6.1 启用了 ViewEncapsulation.ShadowDom 功能,这对 Angular 元素来说非常有用,现在支持在自定义元素中使用 Web 标准进行内容投射。Web 组件规范引入了一个新的标准 HTML 元素,即 Slot。这个功能现已可用,可以通过模板来启用组件。



然后可以像下面这样将其作为 Angular 元素:


新的 ng-compiler

新的 ng-compiler 提供了加速的八阶段编译,并将大型应用程序的大小减少了大约一半。新编译器能够进行八阶段旋转预先编译。大多数应用程序的捆绑尺寸预期可以大幅减少 95-99%。

拆分 @angular/core

Angular 的一个缺点是它的总体功能太多。它是一个大型的框架,本身会为你自动提供可能用不到的模块,因此,Angular 团队已经将 @angular/core 拆分为至少 418 个模块。

Router

增加了新的警告类型,如果你尝试在 Angular 区域之外触发导航就会出现这个警告。如果你这样做不起作用,Angular 会将警告写入日志(仅在开发模式下)。新版本还将导航执行上下文信息添加到 activation hooks 中。

9. 仍然没有 Ivy

Angular 团队并没有承诺最终的时间表,但根据官方博文,Ivy 仍在积极开发中,但不属于 Angular v7。我们期望在版本 8 中会有完整的测试版。你可以在 Angular 官方 GitHub 代码库中的 Ivy Renderer 问题中自行跟进。他们也希望 Ivy 可以在次要版本中发布,只要经过全面测试和验证即可。也许我们会在 Angular 7 的下一个版本中看到它。


10. 文档更新

angular.io 上的文档现在更新了与 Angular CLI 相关的参考资料。

弃用

最新的 Angular 7 版本弃用了一些东西,比如你之前使用在模板中声明表单,这个选择器现在已被弃用,现在应该使用<ng-form>

如何更新到 Angular 7

如果你已经在 Angular 6 和 RXJS 6 上运行 Angular App,只需要更新你的 @angular cli/core 和 Angular Material。




或者访问 update.angular.io 获取有关更新应用程序的详细信息和指南。开发人员报告说,Angular 7 更新速度比以往任何时候都快,很多应用程序的更新时间不到 10 分钟。

Angular 7 其他的新功能:

  • Angular Console——一个可下载的控制台,用于在本地计算机上启动和运行 Angular 项目;

  • @angular/fire——AngularFire 在 npm 上有了新的主页,并为 Angular 提供了第一个稳定版本;

  • NativeScript——现在可以使用 NativeScript 为 Web 和移动设备构建单个项目;

  • StackBlitz——StackBlitz 2.0 已经发布,现在包含了 Angular 语言服务和更多功能,如选项卡编辑;

  • 改进了 Selects 的可访问性(mat-form-field 中的 selectelement);

  • bazel:protractor_web_test_suite 的初始提交;

  • compiler-cli:将 tsickle 更新为 0.29.x;

  • core:将 defaultKeyValueDiffers 导出为私有 API;

  • 平台浏览器:将 HammerJS 延迟加载器符号添加到公共 API 中;

  • Service Worker:为 SW 的通配配置提供支持。

结论

综合上述的所有功能,Angular v7 看起来像是一个专注于迎合现代技术趋势而增加功能的解决方案,如比特币挖掘、虚拟滚动、拖放、Angular Material,等等,但仍然没有在当前版本中包含 Ivy。


Angular 团队在让 Angular 变得更好方面做得非常出色。如果你计划基于 Web 和移动技术实现自己的解决方案,请务必考虑 Angular 7 这个高效的新开发框架。


英文原文:https://www.angularminds.com/blog/article/top-10-features-of-angular-7.html


2018-12-03 13:575787
用户头像

发布了 731 篇内容, 共 433.8 次阅读, 收获喜欢 1997 次。

关注

评论 1 条评论

发布
暂无评论
发现更多内容

遇见乌镇 | VoneCredit洞见供应链金融新未来

旺链科技

世界互联网大会 供应链金融

音视频编解码 --X264码率控制初探

Fenngton

音视频 ffmpeg 编码 码率控制 引航计划

2021金九银十,啃完这35个Java技术栈,冲刺百万年薪不是梦

Java 架构 面试 程序人生 编程语言

【大咖直播】Elastic 企业搜索实战工作坊(第一期)

腾讯云大数据

elasticsearch

PerfDog携手Imagination,助力开发者获取GPU关键数据

WeTest

金九银十面试如何得到面试官青睐?2021最新大厂Java面试真题合集(附权威答案)

Java 架构 面试 程序人生 编程语言

如何撬动企业数字化转型?智能客服是关键支点

ToB行业头条

HarmonyOS荣膺2021世界互联网大会领先科技成果奖

Geek_283163

华为 鸿蒙

论文阅读丨神经清洁: 神经网络中的后门攻击识别与缓解

华为云开发者联盟

神经网络 深度学习 论文阅读

解密秒杀系统架构,不是所有的系统都能做秒杀!

华为云开发者联盟

架构 秒杀 电商系统

云原生时代,如何构建数字化转型架构?

博文视点Broadview

🏆【SpringBoot技术专题】「FtpServer文件服务」教你如何基于Springboot开发一个”可移植“的轻量级文件服务项目系统!

洛神灬殇

Apache springboot ftp服务 9月日更 FtpServer

第5章-《Linux一学就会》- Linux基本操作和服务器硬件选购指南

学神来啦

Linux linux运维 linux学习 Linux教程

如何使用ESD二极管,设计运算放大器电压保护?

不脱发的程序猿

电路设计 ESD二极管 运算放大器 电压保护 嵌入式硬件

让数据库无惧灾难,华为云GaussDB同城双集群高可用方案正式发布

华为云开发者联盟

数据库 高可用 集群 华为云GaussDB 同城双集群

应用开发中的存储架构进化史——从起步到起飞

Java 编程 架构 面试 后端

AI专家一席谈:复用算法、模型、案例,AI Gallery带你快速上手应用开发

华为云开发者联盟

算法 模型 案例 AI Gallery 应用开发

如何管理职场新人?

石云升

团队管理 管理 引航计划 内容合集 9月日更

一文带你掌握工作流引擎flowable所有业务概念

小鲍侃java

后端 引航计划

垂直CRM,能否走到终局?

ToB行业头条

金秋国庆|官微掌门人火热征集!期待你的掌舵!

InfoQ写作社区官方

国庆中秋 热门活动

刷爆Leetcode!字节算法大佬进阶专属算法笔记:GitHub标星97k+

Java 架构 面试 程序人生 LeetCode

三款Linux文件传输工具简单介绍-行云管家

行云管家

Linux 文件传输 IT运维

浅谈语音质量保障:如何测试 RTC 中的音频质量?

阿里云视频云

阿里云 测试 WebRTC 语音 音频

GK架构营模4作业

Ping

阿里内部最新“SpringCloudAlibaba学习笔记”(全彩第三版)限时开源

Java 架构 面试 微服务 Alibaba

国庆临近,字节后端开发3+4面,终于拿到秋招第一个offer

Java 架构 面试 后端 计算机

Linux用户/用户组编辑

在即

9月日更

智云盾捕获多个僵尸网络利用最新ConfluenceRCE漏洞的活动

百度开发者中心

安全 漏洞

等保测评一次多少钱,收费标准是怎样的?

行云管家

网络安全 等保 等保测评 等保2.0

ThingMap一键城市2.0重新出发:快速生成三维城市

ThingJS数字孪生引擎

地图 物联网 可视化 数字孪生

解析Angular 7的十大特性_大前端_Angular Minds_InfoQ精选文章