• 技术文章 >web前端 >js教程

    Angular8+面试题整理之:基础知识点解析

    青灯夜游青灯夜游2022-02-15 11:00:34转载82
    本篇文章给大家整理分享一些基于Angular8+的面试题,带大家深入了解一下Angular8+的基本知识点,希望对大家有所帮助!

    相关推荐:2022年大前端面试题汇总(收藏)

    关于Angular CLI

    Angular CLI又称 Angular脚手架,用于快速生成项目或者组件的框架以提高效率。可以方便的生成angular app、component、service 等等, 并且可以通过参数,按照自己的需求去创建。可以说是angular开发必不可少的利器。【相关教程推荐:《angular教程》】
    参考:https://cli.angular.io/

    关于angular的依赖注入(dependency injection)

    依赖注入是Angular实现的一种应用程序设计模式, 是Angular的核心概念之一。

    依赖就是具有一系列功能的服务(service), 应用程序中的各种组件和指令(derictives)可能需要服务的功能。 Angular提供了一种平滑的机制,通过它我们可以将这些依赖项注入我们的组件和指令中。因此,我们只是在构建依赖关系,这些依赖关系可以在应用程序的所有组件之间注入。

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

    1. 不需要实例化,(new 实例)。不需要关心class的构造函数里需要什么参数
    2. 一次注入(app module通过Providers注入),所有组件都可以使用。而且是用同一个service实例(Singleton),也就是说一个service里的数据是共分享的,可以用于组件间数据传递。

    关于angular的编译,AOT和JIT的区别

    每个Angular应用程序都包含浏览器无法理解的组件和模板。 因此,在浏览器内部运行之前,需要先编译所有Angular应用程序。

    Angular提供两种编译类型:

    区别在于,在JIT编译中,应用程序在运行时在浏览器内部进行编译;而在AOT编译中,应用程序在构建期间进行编译。
    显而易见,AOT编译好处多多,因而是Angular的默认编译方式。主要优点

    Angular双向绑定

    Angular双向绑定的原理

    Angular的双向绑定,通过脏数据检查(Dirty checking)来实现。

    Angular双向绑定效率问题

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

    Angular数据绑定的三种方式

    <div>
        <span>Name {{item.name}}</span>  <!-- 1. 直接绑定 -->
        <span>Classes {{item | classPipe}}</span><!-- 2. pipe方式-->
        <span>Classes {{classes(item)}}</span><!-- 3.绑定方法调用的结果 -->
    </div>

    更多优化技巧,参考 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对象。

    如果提高Angular的性能

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

    Angular 版本如何升级

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

    更多编程相关知识,请访问:编程学习!!

    以上就是Angular8+面试题整理之:基础知识点解析的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:csdn,如有侵犯,请联系admin@php.cn删除
    专题推荐:angular 面试题
    上一篇:探索Node中如何应用反应式编程?优缺点分析 下一篇:浅析JavaScript的继承和原型链
    PHP编程就业班

    相关文章推荐

    • 一起聊聊angular的样式隔离实现机制• 一文聊聊Angular中怎么操作DOM元素• angular与react的区别是什么• 浅析Angular中的可观察对象、观察者和RxJS操作符• 再见AngularJS,欢迎Angular登场!• 一文聊聊angular中的响应式表单

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网