Angular 更新还是非常快的, 目前(2020)的速度是每年2个主版本。网上也有不少面试题,不过很多都是针对老的版本,尤其是AngularJS的。因为最近在看Angular的面试题,所以特意总结一下。下面内容都是基于Angular v8.0以上的。
顺便科普一下,Angular最早期的版本,也叫AnugularJS,使用javascript开发;新的版本,才叫Angular,也称为Angular2,使用typescript开发,Angular和AngularJS是不兼容的(当然也有2个版本的集成方案)。
Angular v8+面试系列
Angular CLI又称 Angular脚手架,用于快速生成项目或者组件的框架以提高效率。可以方便的生成angular app、component、service 等等, 并且可以通过参数,按照自己的需求去创建。可以说是angular开发必不可少的利器。 参考:https://cli.angular.io/
依赖注入是Angular实现的一种应用程序设计模式, 是Angular的核心概念之一。
依赖就是具有一系列功能的服务(service), 应用程序中的各种组件和指令(derictives)可能需要服务的功能。 Angular提供了一种平滑的机制,通过它我们可以将这些依赖项注入我们的组件和指令中。因此,我们只是在构建依赖关系,这些依赖关系可以在应用程序的所有组件之间注入。
使用依赖注入还有以下好处,
每个Angular应用程序都包含浏览器无法理解的组件和模板。 因此,在浏览器内部运行之前,需要先编译所有Angular应用程序。
Angular提供两种编译类型:
区别在于,在JIT编译中,应用程序在运行时在浏览器内部进行编译;而在AOT编译中,应用程序在构建期间进行编译。 显而易见,AOT编译好处多多,因而是Angular的默认编译方式。主要优点
Angular的双向绑定,通过脏数据检查(Dirty checking)来实现。
对于页面中需要绑定DOM元素极其多的情况(成百上千),必然会遇到效率问题。(具体还取决于PC、浏览器性能)。另外,脏检查超过10次(经验值?),就认为程序有问题,不再进行检查。 可以采用如下方式避免
<div>
<span>Name {
{item.name}}</span> <!-- 1. 直接绑定 -->
<span>Classes {
{item | classPipe}}</span><!-- 2. pipe方式-->
<span>Classes {
{classes(item)}}</span><!-- 3.绑定方法调用的结果 -->
</div>
更多优化技巧,参考 angular绑定(脏检查)方面的性能优化技巧
模块(Module)是一个我们可以对组件(Component),服务(service)和管道(pipe)进行分组的地方。 模块通过导出或隐藏这些元素来决定其他模块是否可以使用组件,指令等。 每个模块都使用@NgModule装饰器定义。
每个Angular应用程序只能有一个根模块(Root Module),而它可以有一个或多个功能模块(Feature Module)。根模块导入BrowserModule,而功能模块导入CommonModule。
当一个项目做得很大后,为了提高首屏加载速度,可以通过Lazy-loading,当访问到某些具体的url时,才加载那些不常用的feature module。
实现:正常创建feature module,修改路由配置。 例如:
const routes: Routes = [
{
path: 'customers',
loadChildren: () => import('./customers/customers.module').then(m => m.CustomersModule)
}
];
这样,编译后,这个feature module就会是一个独立的js,只有当用户访问url(~/customers)时,才会向server端请求这个独立的js,然后加载、执行。
参考https://angular.io/guide/lazy-loading-ngmodules
指令(Directive)用于添加行为到已有元素(DOM)或者组件(Component)。 同时,一个元素或组件,可以应用多个指令。
首先新版本的anuglar是推荐使用Observable的(属于RxJS),其次,对于Observable对象,可以使用.toPromise()转化为Promise对象。
Angular也还是网页应用,所以一般的提高网页西能的技巧都是通用的。针对Angular,还有一些特殊的优化技巧:
Angular CLI提供了升级命令(ng update),同时,官网(https://update.angular.io/)也有升级指南。选择从哪个版本升级到哪个版本后,会给出一步一步的升级命令,直接执行就好。
Angular v8+面试系列
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/180660.html原文链接:https://javaforall.cn