首页 > 编程知识 正文

es6新特性 面试题,angular7面试

时间:2023-05-06 16:04:29 阅读:130531 作者:1461

Angular的更新还非常快,目前(2020 )的速度是每年两个主要版本。 网络也有很多问题,但很多是针对旧版本,特别是AngularJS。 因为最近在看Angular的面试问题,所以特意总结一下。下面内容都是基于Angular v8.0以上的

顺便说一下,Angular的最初版本也称为AnugularJS,是使用javascript开发的; 新版本称为Angular,也称为Angular2,是使用typescript开发的。 Angular和AngularJS不兼容。 当然,还有两个版本的集成方案。

Angular v8面试系列

Angular问题集1-基本知识Angular问题集2-Component/ServiceAngular问题集3-设备测试目录Angular CLI中的Angular相关性注入编译Angular AOT和JIT差异Angular双向绑定angular 双向绑定效率问题Angular数据绑定的三种方法关于Angular的模块是什么Angular的模块根模块和feature模块之间的区别。 “模块延迟加载”(Lazy-loading )指令(Directive ) Promise和Observable之间的差异提高Angular的性能会如何升级Angular版本

关于Angular CLI

Angular CLI (也称为Angular脚手架)用于快速生成项目或组件的框架,以提高效率。 可以轻松生成angular app、component、service等,并使用参数根据需要创建。 可以说是开发angular不可缺少的利器。

参考: https://cli.angular.io/

ng generate:新angular appng update:升级angular本身(如ng generate:新组件、服务、pipe和class )和ng version:angular 1 )基于npm安装node _ modules;2 )自动修改配置文件以确保新依赖项正常工作的依赖项注入(依赖项注入)由angular实现

依赖关系是一组功能的服务(service ),APP应用程序中的不同组件和/或指令可能需要服务的功能。 Angular提供了一种平滑的机制,可以将这些依赖关系注入到组件和指令中。 因此,它只是在APP应用程序的所有组件之间建立了可注入的依赖关系。

使用依赖注入还具有以下好处

不需要实例化。 (新实例。 所有组件都可以使用,而不必在意class构造函数需要什么参数。 而且使用的是相同的服务实例(Singleton )。 这意味着单个服务中的数据是共享的,可以用于组件之间的数据传输。 对于angular编译,任何AOT和JIT之间的差异都包含浏览器无法理解的组件和模板。 因此,在浏览器内部执行之前,必须编译所有angular APP应用程序。

Angular有两种编译类型。

JIT(just-in-time ) compilation AOT (JIT-in-compilation ) ahead-of-time (JIT-compilation ) compilation的区别在于,在jion中,APP应用程序在运行时在浏览器内部进行编译。 在AOT编译中,APP应用程序在构建过程中进行编译。

很明显,AOT编译有很多好处,因此是Angular的默认编译方法。 主要好处

由于APP应用程序在浏览器内部运行之前进行编译,因此浏览器可以加载可执行代码并立即渲染APP应用程序,从而减少渲染时间。 在AOT编译中,编译器将与APP应用程序一起发送外部HTML和CSS文件,从而消除了对它们的源文件的单独AJAX请求,减少了AJAX请求。 开发人员可以在构建阶段检测和处理错误,从而最大限度地减少错误。 AOT编译器将HTML和模板添加到JS文件中,并在浏览器中运行。 因此,没有很多可读取的HTML文件,从而提高了APP应用程序的安全性。 Angular双向绑定Angular双向绑定原理Angular的双向绑定通过脏数据检查(Dirty checking )实现。

脏值检测的基本原理是存储旧值,在检测时对照当前时刻的新值和旧值。 如果相等,则没有变化;相反,则需要检测变化并更新视图。 在angular2中有Zone.js。 对于setTimeout,所有高级监听器、promise等都在ngZone上运行。 这意味着它将被重写为zone.js包。 angular通知ngZone设置适当的挂接,并对angular2进行适当的脏检查处理。 Angul

ar双向绑定效率问题

对于页面中需要绑定DOM元素极其多的情况(成百上千),必然会遇到效率问题。(具体还取决于PC、浏览器性能)。另外,脏检查超过10次(经验值?),就认为程序有问题,不再进行检查。
可以采用如下方式避免

对于只用于展示的数据,使用单向绑定,而不是双向绑定;Angular的数据流是自顶而下,从父组件到子组件单向流动。单向数据流向保证了高效、可预测的变化检测。因而组件化也是提高性能的一种手段。表达式(以及表达式所调用的函数)中少写太过复杂的逻辑不要连接太长的 pipe(往往 pipe里都会遍历并且生成新数组, pipe 在anglarJS(v1)中叫做filter)变化检测策略onPush. Angular有两种变化检测策略。Default是Angular默认的变化检测策略,也就是上述提到的脏检查(只要有值发生变化,就全部检查)。开发者可以根据场景来设置更加高效的变化检测方式:onPush。onPush策略,就是只有当输入数据的引用发生变化或者有事件触发时,组件才进行变化检测。NgFor应该伴随trackBy方程使用。否则,每次脏值检测过程中,NgFor会把列表里每一项都执行更新DOM操作。 Angular数据绑定的三种方式 <div> <span>Name {{item.name}}</span> <!-- 1. 直接绑定 --> <span>Classes {{item | classPipe}}</span><!-- 2. pipe方式--> <span>Classes {{classes(item)}}</span><!-- 3.绑定方法调用的结果 --></div> 直接绑定: 大多数情况下,这都是性能最好的方式。绑定方法调用的结果:在每个脏值检测过程中,classes方程都要被调用一遍。如果没有特殊需求,应尽量避免这种使用方式。pipe方式: 它和绑定function类似,每次脏值检测classPipe都会被调用。不过Angular给pipe做了优化,加了缓存,如果item和上次相等,则直接返回结果。

更多优化技巧,参考 angular绑定(脏检查)方面的性能优化技巧

关于angular的Module 什么是angular的Module

模块(Module)是一个我们可以对组件(Component),服务(service)和管道(pipe)进行分组的地方。 模块通过导出或隐藏这些元素来决定其他模块是否可以使用组件,指令等。 每个模块都使用@NgModule装饰器定义。

Root Module和Feature Module的区别。

每个Angular应用程序只能有一个根模块(Root Module),而它可以有一个或多个功能模块(Feature Module)。根模块导入BrowserModule,而功能模块导入CommonModule。

Module 延迟加载(Lazy-loading)

当一个项目做得很大后,为了提高首屏加载速度,可以通过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)

指令(Directive)用于添加行为到已有元素(DOM)或者组件(Component)。
同时,一个元素或组件,可以应用多个指令。

Promise 和 Observable的区别

首先新版本的anuglar是推荐使用Observable的(属于RxJS),其次,对于Observable对象,可以使用.toPromise()转化为Promise对象。

Promise,无论是否调用then。promise都会立即执行;而observables只是被创建,当调用(subscribe)的时候才会被执行。Promise返回一个值;Observable返回0至N个值。所以Promise对应的操作符是.then(),Observable对应的是.subscribeObservable,还额外支持map,filter,reduce和相似的操作符Observable 可以取消,Promise不可以 如果提高Angular的性能

Angular也还是网页应用,所以一般的提高网页西能的技巧都是通用的。针对Angular,还有一些特殊的优化技巧:

AOT编译。之前提到过不要在客户端编译应用程序已经最小化(uglify和tree shaking)去掉不必要的import语句。如果有遗留,那么打包时也会打进来。确保应用中已经移除了不使用的第三方库。同上。项目较大时,考虑延迟载入(Lazy Loading), 保证首页的加载速度。 Angular 版本如何升级

Angular CLI提供了升级命令(ng update),同时,官网(https://update.angular.io/)也有升级指南。选择从哪个版本升级到哪个版本后,会给出一步一步的升级命令,直接执行就好。

Angular v8+面试系列

Angular 面试题汇总1-基本知识Angular 面试题汇总2-Component/ServiceAngular 面试题汇总3-单元测试





版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。