首页
学习
活动
专区
圈层
工具
发布

【17】进大厂必须掌握的面试题-50个Angular面试

Angular中的指令是什么? Angular的核心功能是指令,这些属性使您可以编写 特定于应用程序的新HTML语法。它们本质上是在Angular编译器在DOM中找到它们时执行的函数。...使用它们,您可以轻松地组织数据,使数据仅在满足特定条件时才显示。通过使用竖线字符|,将过滤器添加到表达式中,然后是过滤器。 14. Angular和jQuery有什么区别?...Angular支持创建以下内容的自定义指令: 元素指令 -当遇到匹配的元素时,指令将激活。 属性 -当遇到匹配的属性时,指令将激活。...40.您对Angular中的REST了解那些? REST表示RE表象小号大老牛逼转让(BOT)。REST是适用于HTTP请求的API(应用程序编程接口)样式。...在这种情况下,所请求的URL可以精确定位需要处理的数据。然后,HTTP方法将标识需要对请求的数据执行的特定操作。因此,遵循此方法的API被称为RESTful API。 41.

45.9K51

Angular的12个经典问题,看看你能答对几个?(文末附带Angular测试)

Angular提供了一组生命周期hooks(特殊事件),可以被分接到生命周期中,并在需要时执行操作。构造函数会在所有生命周期事件之前执行。每个接口都有一个前缀为ng的hook方法。...这是最常用的方法,用于从后端服务检索模板的数据。 ngDoCheck:检测并在Angular上下文发生变化时执行。每次更改检测运行时,会被调用。...这通常用在setter中,当类中的值被更改完成时。 可以通过模块的任何一个组件,使用订阅方法来实现事件发射的订阅。...如何在Angular 2中启用延迟加载? 大多数企业应用程序包含用各式各样的用于特定业务案例的模块。捆绑整个应用程序代码并完成加载,会在初始调用时,产生巨大的性能开销。...Observables和Promises的核心区别是什么? 从堆栈溢出就是一个区别:  当异步操作完成或失败时,Promise会处理一个单个事件。

24.8K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    手动调用 Observable subscribe 的时机与案例探讨

    有些时候, 手动调用 Observable 的 subscribe 方法, 才能完成更复杂或者更灵活的业务需求。...若仅依赖 AsyncPipe, 可能会让代码结构变得生硬, 甚至无法满足在特定条件下进行再次订阅或暂时取消订阅的需求。此时, 通过手动调用 subscribe 就能更加灵活地实现各种流程管理。...例如, 在发起网络请求之前, 需要先进行本地缓存或权限校验, 然后在拿到结果数据时还要执行系列计算或调用多个不同的服务接口。...部分场景也会用到更高级的操作符, 像 switchMap、mergeMap 等, 与手动订阅配合时更容易在合适的时机执行某些特定副作用, 这也进一步说明了手动调用 subscribe 的优势。...以上内容, 涉及了多角度阐述为什么在 Angular 应用中需要手动调用 Observable 实例的 subscribe 方法, 也提供了能够运行的示例代码。

    16410

    前端人员该怎么面试 经典Angular面试题有哪些

    当@angular/core的数据绑定属性更改时,处理就会更改,在从DOM中删除其模板之前,就会销毁掉它。...Angular提供了一组生命周期hooks(特殊事件),可以被分接到生命周期中,并在需要时执行操作。构造函数会在所有生命周期事件之前执行。每个接口都有一个前缀为ng的hook方法。...6)如果应用程序较大时,我会考虑延迟加载而不是完全捆绑的应用程序。 4、什么是Shadow DOM?它如何帮助Angular 2更好地执行?...它们之间的唯一区别是:service方法用于注入的结果通常是new出来的对象,factory方法注入的结果通常是一系列的functions; provider是创建服务最为复杂的方法,除非你需要创建一个可以复用的代码段并且需要进行全局配置...,才需要使用provider创建; 所有具有特定性目的的对象都是通过factory方法去创建。

    5.4K80

    Angular 从入坑到挖坑 - HTTP 请求概览

    一、Overview angular 入坑记录的笔记第四篇,介绍在 angular 中如何通过 HttpClient 类发起 http 请求,从而完成与后端的数据交互。...在执行服务中的方法时,有时会存在没有回调函数的情况,此时也必须执行 subscribe 方法,否则服务中的 HTTP 请求是没有真正发起的 服务中的 getAntiMotivationalQuotes...因为这里是以默认的表单提交的方式进行的数据提交,当后端需要修改请求的 body 格式时,则需要我们修改请求的 MIME 类型 当需要更改请求的 MIME 类型或是需要添加授权访问的 token 信息这一类的操作时...; } } 当请求发生错误时,通过在 HttpClient 方法返回的 Observable 对象中使用 pipe 管道将错误传递给自定义的错误处理器,从而完成捕获错误信息的后续操作 ?...当一个拦截器已经处理完成时,需要通过 next 对象将 HTTP 请求传递到下一个拦截器,否则,整个请求将会中断。

    7.6K10

    《解构Angular组件变化检测:从自动到手 动的效能突破》

    在实际应用中,这种遍历机制的性能表现会受到组件嵌套深度的显著影响。一个深度为10层、每层包含10个组件的应用,单次检测需要执行100次组件检查;而当深度增加到20层时,检查次数会翻倍。...当一个事件(如点击)发生时,Angular会先执行所有同步代码,然后处理该事件引发的所有微任务(如Promise的回调),最后才启动变化检测。...比如,当应用集成了第三方库时,这些外部代码的异步操作往往处于Angular的监测范围之外,其引发的数据变更可能无法被自动检测捕捉,此时便需要手动唤醒检测机制以同步视图。...这种模式适用于那些长时间处于稳定状态,仅在特定条件下才需要更新的组件,如数据可视化图表或静态信息展示面板。...在默认策略中,Angular会检查输入属性的深层值是否变化,而OnPush策略仅比较引用是否相同。这意味着,若只是修改输入对象的某个属性而不改变引用,采用OnPush策略的组件不会触发检测。

    23110

    RxJS 处理多个Http请求

    有时候进入某个页面时,我们需要从多个 API 获取数据然后进行页面显示。管理多个异步数据请求会比较困难,但我们可以借助 Angular Http 服务和 RxJS 库提供的功能来实现上述的功能。...仅当内部的 Observable 对象发出值后,才会合并源 Observable 对象输出的值,并最终输出合并的值。...forkJoin forkJoin 是 RxJS 版本的 Promise.all(),即表示等到所有的 Observable 对象都完成后,才一次性返回值。...http 对象的 get() 方法来获取数据。...这个例子很简单,它只处理一个请求,接下来我们来看一下如何处理两个请求。 Map 和 Subscribe 有些时候,当我们发送下一个请求时,需要依赖于上一个请求的数据。

    7.4K20

    AngularDart4.0 英雄之旅-教程-08HTTP 顶

    让用户添加,编辑和删除英雄的名字。 将更改保存到服务器。 您将教会应用程序对远程服务器的Web API进行相应的HTTP调用。 当你完成这个页面,应用程序应该看起来像这个实例(查看源代码)。...请注意服务器返回的数据的形状。 这个特定的内存web API示例返回一个具有data属性的对象。 你的API可能会返回其他的东西。 调整代码以匹配您的Web API。...对于模拟来说这很好,但是当你只需要一个真正的服务器给所有英雄时,这是浪费的。 大多数web API支持以api / hero /:id(如api / hero / 11)的形式获取请求。...distinct()确保仅当过滤器文本发生更改时才发送请求。 transform(switchMap(...))为通过debounce()和distinct()创建的每个搜索项调用搜索服务。...终点直道 你在旅程的尽头,你已经完成了很多。 您添加了必要的依赖关系,以在应用程序中使用HTTP。 您重构了HeroService以从Web API加载英雄。

    12.9K30

    前端面试题angular_Vue前端面试题

    第一点区别是,ng-if 在后面表达式为 true 的时候才创建这个 dom 节点,ng-show 是初始时就创建了,用 display:block 和 display:none 来控制显示和不显示。...当浏览器接受到可以被angular context处理的事件时就会触发digest循环,这个循环是由两个更小的循环组合起来的,一个是watch列表,一个是evalAsync列表,而watch列表在digest...当digest循环结束时,DOM相应地变化。...貌似在 Angular1.x 中并没有很好的解决办法,所以最好在前期进行统一规划,做好约定,严格按照约定开发,每个开发人员只写特定区块代码。 9、angular 的缺点有哪些?...digest仅会检查该scope和它的子scope,当你确定当前操作仅影响它们时,用 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

    15.6K20

    TW洞见〡为什么你的Angular代码很难测试?

    今天的Web开发已经不同往日,更多的交互与逻辑都需要在前端完成,有时候,前端的代码量甚至在后端之上。怎么去保证如此多的前端逻辑不被破坏,依赖于功能测试?...,反馈时间太长了,可能你要等一分多钟才知道某个功能出错了,我们自然不想把宝贵的开发时间浪费在等待上。...而版本二就简单多了,只定义了一个Model值isValid来标识当前的邮箱地址是否合法, validate()方法会在每次失焦之后自动执行,要为它添加单元测试,则只需要调用一下它的validate()方法...这里的处理办法是将快递地址验证失败或成功之后的处理函数都传给了deliveryService,当验证结果从服务器端返回之后,相应的处理函数会被执行。这做写法其实是比较常见的,但是问题出在哪里呢?...所以,如果你的处理函数是传递给service中的API的话,那么你的测试其实就已经跟这个API的实现绑定了,你只有去创建一个真实的service并且让它发送HTTP请求,你的处理函数才会被执行到。

    2K30

    angular面试题及答案_angular面试

    ngOninit:初始化指令或组件,在angular第一次显示展示组件的绑定属性后调用,该方法只会调用一次 ngDocheck:检测 ngAfterContentInit:当把内容投影进组件之后调用,...当observable或promise返回data时,我们使用一个临时属性来保存内容。稍后,我们将相同的内容绑定到模板。...– 下载代码 – 启动angular – 页面渲染 AOT优势   1、渲染得更快   2、需要的异步请求更少   3、需要下载的Angular框架体积更小...当没有配置base标签时,加载应用会失败。 23....是输入属性发生变化的时候调用,并且ngOnInit是在ngOnchanges执行之后才调用,而constructor是在组件实例化的时候就调用了,也就是说,在constructor中是取不到输入属性的值的

    15.4K120

    Angular 与 rxjs 中 take(1) 的运用解析

    某些业务场景下,我们仅需要该流中第一个数据项,例如在获取一次性数据或者 HTTP 请求时,期望只关注第一份返回数据,而忽略后续数据。...take(1) 操作符正是为此设计,其工作原理为:订阅数据流后,当数据流发出第一个数据时,该操作符会立即传递该数据给订阅者,并自动完成订阅。此时,数据流中剩余的后续数据不再被监听。...采用 take(1) 能够确保当仅需要一次数据获取的场景中,Observable 自动结束数据传输,这样可以防止长期存在的订阅导致资源浪费以及内存泄漏问题。...下面展示一个简单示例,说明在 Angular 组件中利用 RxJS 中的 of 操作符创建一个数据流,然后使用 pipe 方法配合 take(1) 操作符对该数据流进行截取,进而只获取第一个数据项后自动完成订阅...通过阅读本文提供的源代码与解释,可以清晰地看到当数据流发出第一项数据时,take(1) 操作符会自动终止订阅,从而将数据流的生命周期控制在期望范围内。

    69600

    Angular v20 版本发布

    从那时起,我们引入了资源流并创建了一个名为 httpResource 的新 API,允许您使用基于 Signal 的反应式 API 进行 HTTP 请求。...return fetch(`users/${request.id}`, {signal: abortSignal}); }, }); 当 userId 信号变化时,上述代码将获取具有特定标识符的用户...@defer (hydrate on viewport) { } 这样,Angular 将会下载购物车组件及其传递依赖,并且仅在它进入视口时才初始化这部分 UI。...这次新集成旨在通过在同一时间轴上显示 Angular 运行时数据,如组件渲染、变更检测周期和事件监听器执行,来解决这一问题。...在我们从一个 RFC 收集反馈后,我们引入了一系列简化措施——从风格指南中移除非 Angular 特定的代码健康实践,并将与编码风格无关的 Angular 最佳实践移至文档中。

    1.6K10

    【ASP.NET Core 基础知识】--前端开发--集成前端框架

    这些方法允许开发者在组件的不同生命周期阶段执行特定的操作,如初始化数据、处理更新等。 状态管理: React组件可以拥有自己的状态(state),状态的变化会触发组件重新渲染。...这种数据流清晰明确,有助于跟踪数据的变化,提高了代码的可维护性。 生命周期方法: React组件具有丰富的生命周期方法,允许开发者在组件的不同阶段执行特定的操作。...ConfigureServices 方法中添加以下代码以启用 Web API 路由。...的主页面 await next(); } }); 处理路由冲突 当使用 Angular 路由时,需要确保前端路由和后端路由不会发生冲突。...使用 CDN 来加速静态资源的加载,减轻服务器负载。 编译优化 使用编译器优化选项来生成高效的机器代码,提高代码的执行效率。 避免在运行时进行大量的动态代码生成和反射操作,尽量在编译时完成。

    4.7K00

    在 Asp.Net Core WebAPI 中防御跨站请求伪造攻击

    或者 session riding,通常缩写为 CSRF 或者 XSRF, 是一种挟制用户在当前已登录的Web应用程序上执行非本意的操作的攻击方法。...~/api/security/xsrf-token 时, 服务端发送两个 Cookie : .AspNetCore.Antiforgery.xxxxxx 一个 HTTP Only 的 Cookie ,...XSRF 认证,除了 GET, HEAD, OPTIONS 和 TRACE 之外的方法才支持 XSRF 认证。...Angular 内置支持 Angular 的 Http 模块内置支持 XSRF , 前提条件如下: 存在客户端可以操作的名称为 XSRF-TOKEN 的 Cookie ; 该 Cookie 不能是 HttpOnly...的, 否则客户端脚本无法读取; 该 Cookie 的 Path 必须为 / ; 这三个条件都满足, 则在向服务端请求时自动发送名称为 X-XSRF-TOKEN 的 Header , 值则为 XSRF-TOKEN

    2.5K10

    Angular 应用中手动调用 subscribe 方法的时机与实践探讨

    subscribe 方法 当数据仅仅用于展示时 使用 async pipe 能够简化代码与提升代码可读性 然而在业务逻辑中 往往需要获取 Observable 发出的数据以进行进一步的处理或触发额外的副作用...中 HttpClient 模块返回的 Observable 实例默认是冷 Observable 只有在订阅后才会真正发起 HTTP 请求 在需要调用外部 API 或后端服务时 开发者常常需要手动调用...subscribe 方法来启动请求并处理响应数据 此时不仅需要关注数据的获取 还必须处理可能出现的异常情况与请求完成后的清理工作 这类场景下手动调用 subscribe 方法成为必然选择Angular...API 进行调用时 手动订阅 Observable 所带来的便利与必要性 在此场景中 HttpClient 返回的 Observable 是冷 Observable 只有在订阅后才会执行 HTTP 请求...方法的时机主要出现在需要主动启动 Observable 数据流、实现复杂业务逻辑、捕捉异步错误、以及进行状态更新与资源管理时 开发者应充分理解 Observable 的执行机制与 Angular 生命周期的关系

    45810

    JSON Web Token(JWT)教程:一个基于Laravel和AngularJS的例子

    文章内容 随着单页应用程序,移动应用程序和RESTful API服务的日益普及,Web开发人员编写后端代码的方式发生了重大变化。...跨源请求共享(CORS):当使用AJAX调用从另一个域(跨域,Cross-origin)获取资源时,我们可能会遇到禁止请求的问题,因为默认情况下,HTTP请求不包括跨域(Cross-origin)请求的...与Web框架耦合:当使用基于服务器的身份验证时,我们用在我们的框架的身份验证方案,在使用不同编程语言编写的不同Web框架之间共享会话数据是非常困难的,甚至是不可能的。 基于token的身份验证 ?...当我们向一个API 服务器( server),如 api.jwt.dev/v1/restricted发出POST请求时,我们正在进行跨域请求,并且必须在后端启用CORS。...'; }); }]); 仅当用户进行身份验证成功后,后端才负责提供受限制的数据。

    35.6K10

    Angular 16 正式版发布

    用户通常希望在相关Subject完成时完成一个流,以下模式非常常见: destroyed$ = new ReplaySubject(1); data$ = http.get('...').pipe...自从 Qwik 从谷歌的封闭源代码框架 Wiz 中推广了可恢复性的想法以来,我们在 Angular 中收到了许多关于这一功能的请求。...4.1 输入必填(Required inputs) 自从我们在 2016 年引入 Angular 以来,如果不为特定输入指定值,就不可能出现编译时错误。...由于 Angular 编译器在构建时执行检查,因此此更改在运行时增加了零开销,多年来,开发人员一直在要求这个功能,我们得到了一个强有力的指示,这将非常方便!...DestroyRef 可以被注入到注入上下文中的任何位置,包括组件之外 —— 在这种情况下,当相应的注入器被销毁时,ngDestroy 钩子就会被执行: import { Injectable, DestroyRef

    4.6K10
    领券