首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

angular面试题及答案_angular面试

当observable或promise返回data时,我们使用一个临时属性来保存内容。稍后,我们将相同的内容绑定到模板。...module声明了哪些模块可以被其他模块使用,依赖注入了哪些类,以及启动的component,模块来管理组件,使app实现模块化。 21. 怎样在组件中选择一个元素?...Constructor 和 ngOnInit 的本质区别 Constructor 在ES6中 constructor表示构造函数,使用在class中。来初始化操作。...当类被初始化之后,构造函数会被调用 ngOnInit ngOnInit 是angular中OnInit钩子的实现,用来初始化组件。...6)如果应用程序较大时,我会考虑延迟加载而不是完全捆绑的应用程序。 27. 使用Angular的好处 可以添加自定义的directive. 优秀的社区支持。 客户端和服务器的通讯非常便利。

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

    Angular--Module的使用

    Angular 是一个用html 和typescript 构建客户端应用的平台与框架。 它将核心功能和可选功能作为一组TypeScript 库进行实现,你可以把它们导入到你的应用中。 1....@NgModule() 装饰器是一个函数,参数是一个元数据对象,元数据对象的属性用于描述这个模块。...imports(导入表) —— 其他模块,本NgModule声明的组件需要使用它们的导出类。 providers —— 本模块向全局服务中贡献的那些服务的创建器。 这些服务能被本应用中的任何部分使用。...@NgModule 的参数是一个元数据对象,用于描述如何编译组件的模板,以及如何在运行时创建注入器。...()时 HttpClientModule @angular/common/http 当要和服务器对话时

    4.9K40

    Angular快速学习笔记(2) -- 架构

    使用管道: {{interpolated_value | pipe_name}} 在需要处理的值后面,加上|, 管道还能接收一些参数,来控制它该如何进行转换。...如何使用: 在 Angular 中,要把一个类定义为服务,就要用 @Injectable 装饰器来提供元数据,以便让 Angular 可以把它作为依赖注入到组件中 使用 @Injectable 装饰器来表明一个组件或其它类...通常在构造函数,注入依赖的service: constructor(private service: HeroService) { } 当 Angular 发现某个组件依赖某个服务时,它会首先检查是否该注入器中已经有了那个服务的任何现有实例...你可以在模块中或者组件中注册这些提供商。 - 当你往根模块中添加服务提供商时,服务的同一个实例会服务于你应用中的所有组件。...1.4 路由(Routing) Angular 的 Router 模块提供了一个服务,它可以让你定义在应用的各个不同状态和视图层次结构之间导航时要使用的路径。

    5.3K20

    AngularDart4.0 指南-体系结构概述 顶

    您可以通过使用Angular的标记组合HTML 模板,编写组件类来管理这些模板,在服务中添加应用程序逻辑以及在模块中装入组件和服务来编写Angular应用程序。 然后,通过引导根模块启动应用程序。...当Angular呈现它们时,它根据指令给出的指示转换DOM。 指令是一个带有@Directive注解的类。...大多数依赖是服务。 Angular使用依赖注入来为新组件提供他们需要的服务。 Angular可以通过查看构造函数参数的类型来判断组件需要哪些服务。...如果请求的服务实例不在容器中,那么在将服务返回给Angular之前,注入器将创建一个并将其添加到容器中。 当所有请求的服务已经解析并返回时,Angular可以用这些服务作为参数调用组件的构造函数。...提供者是可以创建或返回服务的东西,通常是服务类本身。 无论应用程序组件树中的级别如何,您都可以在引导期间或组件中注册提供程序。

    7.9K30

    【Angular专题】 (3)装饰器decorator,一块语法糖

    考虑到javascript中函数参数为对象时只传递地址这一特性,装饰者模式实际上是非常好复现的,掌握其基本知识对于理解Angular技术栈的原理和执行流程是必不可少的,从结果的角度来看,使用装饰器和直接修改类的定义没有什么区别...__testable);//false 另一方面,我们可以使用工厂函数的方法生成一个可接收附加参数的装饰器,借助高阶函数的思路不难理解,例如Angular中常见的这种形式: //Angular中的组件定义...它接收如下三个参数: 1.静态成员时参数是类的构造函数,实例成员时传入类的原型对象。...2.5 参数装饰器 参数装饰器一般用于装饰参数,在类构造函数或方法声明中装饰形参。 它在运行时被当做函数调用,传入下列3个参数: 1.静态成员时接收构造函数,实例成员时接收原型对象。...} } 在Typescript中,装饰器的运行顺序基本依照参数装饰器,方法装饰器,访问符装饰器,属性装饰器,类装饰器这样的顺序来运行,所以参数装饰器和方法装饰器可以联合使用实现一些额外功能。

    1.2K30

    【Angular专题】——(2)【译】Angular中的ForwardRef

    问题点在哪里 先做一个小声明,我们现在拥有一个AppComponent,并使用DI系统向其中注入了一个NameService,因为我们使用的是Typescript,所以需要做的工作就是在构造函数的参数中声明变量...无论如何,当我们在调试器中打开Pause on caught exceptions功能时,就会在Angular框架中捕获这个错误: Cannot resolve all parameters for...不对Class定义进行提升的理由 先来理解一下Javascript语言的机制,Javascript解释器不进行类的提升,是因为变量提升会导致在使用extend关键字实现继承时会导致错误,例如当被继承者是一个合法的函数表达式时...从上面的示例中不难看出,如果Javascript解释器对class声明也进行提升处理,就容易在类继承时出现基类未定义的错误。 三. class在使用前必须声明吗?...小结 这个场景并不会经常出现,一般它只在当我们想要注入在同一个文件中声明的类时才会发生,大多数情况下我们在一个文件中只会声明一个类,并且会在文件的头部引入其他依赖的类,以此来保证不会被class不进行变量提升的特性造成困扰

    3.2K20

    Angular 2 架构(下)

    当 Angular 渲染它们时,它会根据指令对 DOM 进行修改。 指令是一个带有"指令元数据"的类。在 TypeScript 中,要通过 @Directive 装饰器把元数据附加到类上。...---- 服务(Services) Angular2中的服务是封装了某一特定功能,并且可以通过注入的方式供他人使用的独立模块。 服务分为很多种,包括:值、函数,以及应用所需的特性。...这种控制反转,运行注入的特点即是依赖注入的精华所在。 Angular 能通过查看构造函数的参数类型,来得知组件需要哪些服务。...例如, SiteListComponent 组件的构造函数需要一个 SiteService: constructor(private service: SiteService) { } 当 Angular...当所有的服务都被解析完并返回时, Angular 会以这些服务为参数去调用组件的构造函数。 这就是依赖注入 。

    2.2K20

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

    Angular提供了一组生命周期hooks(特殊事件),可以被分接到生命周期中,并在需要时执行操作。构造函数会在所有生命周期事件之前执行。每个接口都有一个前缀为ng的hook方法。...简而言之,EventEmitter是在@ angular/core模块中定义的类,由组件和指令使用,用来发出自定义事件。...这通常用在setter中,当类中的值被更改完成时。 可以通过模块的任何一个组件,使用订阅方法来实现事件发射的订阅。...如何优化Angular 2应用程序来获得更好的性能? 优化取决于应用程序的类型和大小以及许多其他因素。但一般来说,在优化Angular 2应用程序时,我会考虑以下几点: 考虑AOT编译。...Observable类似于(在许多语言中的)Stream,当每个事件调用回调函数时,允许传递零个或多个事件。

    17.4K80

    AngularDart4.0 指南- 依赖注入 顶

    Car构造函数并不要求它们,而是从特定的Engine类和Tires类中实例化自己的副本。 如果Engine类发展而它的构造函数需要一个参数呢?...该组件不应该使用new创建HeroService。 它应该要求注入HeroService。 您可以通过指定具有依赖类型的构造函数参数来告诉Angular在组件的构造函数中注入依赖项。...Angular可以注入由该谱系中的任何注射器提供的服务。 测试组件 早些时候,你看到设计一个依赖注入类使得类更容易测试。 列出依赖作为构造函数参数可能是所有你需要有效地测试应用程序部分。...当您使用HeroService类类型定义构造函数参数时,Angular知道注入与该HeroService类令牌关联的服务: HeroListComponent(HeroService heroService...概要 你在这个页面学习了Angular依赖注入的基础知识。 您可以注册各种提供程序,并且您知道如何通过向构造函数添加参数来请求注入的对象(如服务)。 Angular依赖注入比本页描述的更有能力。

    5.7K20

    TypeScript 简介及编码规范

    当一个函数没有返回值时,你通常会见到其返回值类型是 void: // 声明函数返回值为void function warnUser(): void { console.log("This is...let {name, ...rest} = person; TypeScript Interface 在面向对象语言中,接口(Interfaces)是一个很重要的概念,它是对行为的抽象,而具体如何行动需要由类...TypeScript 中的接口是一个非常灵活的概念,除了可用于对类的一部分行为进行抽象以外,也常用于对「对象的形状(Shape)」进行描述。...TypeScript Class 在面向对象语言中,类是一种面向对象计算机编程语言的构造,是创建对象的蓝图,描述了所创建的对象共同的属性和方法。...Accessors 在 TypeScript 中,我们可以通过 getter 和 setter 方法来实现数据的封装和有效性校验,防止出现异常数据。

    10.6K40

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

    一、Overview angular 入坑记录的笔记第四篇,介绍在 angular 中如何通过 HttpClient 类发起 http 请求,从而完成与后端的数据交互。...类,然后通过依赖注入的方式注入到应用类中 在通常情况下,我们需要将与后端进行交互的行为封装成服务,在这个服务中完成对于获取到的数据的处理,之后再注入到需要使用该服务的组件中,从而确保组件中仅仅包含的是必要的业务逻辑行为...在执行服务中的方法时,有时会存在没有回调函数的情况,此时也必须执行 subscribe 方法,否则服务中的 HTTP 请求是没有真正发起的 服务中的 getAntiMotivationalQuotes...4.1.3、提交数据到服务端 在同后端接口进行交互时,获取数据一般用的是 get 请求,而当进行数据新增、更新、删除时则会使用 post、put、delete 这三个 HTTP 谓词 在毒鸡汤这个接口中...({ providedIn: 'root' }) export class AntiMotivationalQuotesServicesService { // 通过构造函数注入的方式依赖注入到使用的类中

    5.3K10

    一统江湖的大前端(10)——inversify.js控制反转

    “依赖注入”的模式就是为了解决以上的问题而出现的,在这种编程模式中,我们不再接收构造参数然后手动完成子模块的实例化,而是直接在构造函数中接受一个已经完成实例化的对象,在代码层面的基本实现形式变成了下面的样子...当构造函数需要使用其他类的实例时,IOC容器会自动完成对依赖的分析,生成需要的实例并将它们注入到构造函数中,当然需要以单例模式来使用的实例都会保存在缓存中。...如果你仔细观察上面的代码,很容易就会发现依赖注入的痕迹,Controller在定义时接收了一个字符串key和一个函数,这个函数通过形参userService来接收外部传入的同名服务,用户要做的仅仅是使用...其他类型装饰器的基本工作原理也是一样的,只是函数签名中的参数不同,例如方法装饰器被调用时会传入3个参数: 第1个参数装饰静态方法时为构造函数,装饰类方法时为类的原型对象 第2个参数是成员名...(也就是前文中定义的types),实例化一个元信息对象,然后根据形参的类型来调用不同的处理函数,当装饰器作为参数装饰器时,第三个参数index是该参数在函数形参中的顺序索引,是数字类型的,否则将认为该装饰器是作为属性装饰器使用的

    3.5K30

    8分钟为你详解React、Angular、Vue三大框架

    React中声明组件的两种主要方式是通过功能函数组件和基于类的组件。 功能函数组件 功能组件是用一个函数声明,用来返回一些JSX。 ? 类组件 基于类的组件是使用ES6类来声明的。...Hooks是让开发者从函数组件中 "钩入"React状态和生命周期特性的函数。它们使代码具有更强的可读性且更易理解。Hooks并不在类组件内工作,它的终极目标是在React中消除类组件的存在。...Hooks规则 Hooks也有一些规则,在使用Hooks之前必须遵循这些规则: 钩子只能在顶层调用(不能在循环或if语句中调用)。 钩子只能在React函数组件中调用,不能在普通函数或类组件中调用。...Typescript部分 ? 路由 ? 数据管理 定义服务类 ? 调用服务类 ?...这个模板(根据传递到路由器中的参数变化)将被渲染到DOM的div#app里面的。

    22.2K20

    TypeScript 入门指南:从 JavaScript 到强类型的开发世界

    了不起: 在 JavaScript 中,变量的类型可以在运行时动态改变。而在 TypeScript 中,你可以在编写代码时为变量、函数参数和返回值等添加类型注解。...同时,函数的返回值类型也被指定为 number。这样,当你在调用这个函数时,编译器会检查参数的类型是否正确,并且返回值也符合预期。 同事: 哇,这真的很方便!还有其他有用的功能吗? 了不起: 当然!...TypeScript 还支持接口、类、模块等高级特性。通过接口和类,你可以更好地组织和管理你的代码。接口定义了对象的结构和行为,而类则是对象的构造函数和方法的集合。...了不起: 当使用 TypeScript 进行开发时,有几个注意事项可以帮助你更好地使用它: 类型定义:TypeScript 是一种静态类型语言,因此在编写代码时需要为变量、函数参数和返回值等明确地添加类型注解...第三方库的类型定义:当使用第三方 JavaScript 库时,它们可能没有提供 TypeScript 的类型定义文件(.d.ts)。

    26820

    使用Ionic2开发Todo应用0 开始之前1 创建新的Ionic 2工程2. 设置主页(Home page)3 持久化数据保存4 总结

    我们可以在构造函数上面声明变量,像上面这样的使其成员变量 member variables,这意味着他们可以通过引用this.myVal在整个类中被被访问,同时,它也将在您的模板中可用。...哦不是,还记得之前我们如何给homePage分配一个any类型变量吗?现在我们在构造函数中分配一个NavController类型给navCtrl参数。...我们不使用@component装饰,而使用@Injectable声明这个类。 在构造函数中,我们建立一个 Storage 服务的引用。...再次,我们importing数据服务,通过传递给构造函数。我们依然设置 items 开始是空的,使用数据服务获取数据。 重要的是要注意getData 返回promise而不是数据本身。...4 总结 在本教程中我们已经介绍了如何实现很多Ionic 2应用的常用功能: 创建视图 监听和处理事件 视图之间的导航 在视图之间传递数据 建立双向数据绑定 保存数据 显然还有很多我们可以做,使这个应用程序更漂亮

    6.1K50

    30个小知识让你更清楚TypeScript

    它使用相同的范围规则,let并有助于降低整体程序的复杂性。 const num:number = 100; 10、在TypeScript中如何从子类调用基类构造函数?...你可以使用该super()函数来调用基类的构造函数。...这与JS相比如何? 全局作用域:在任何类之外定义,可以在程序中的任何地方使用。 函数/类范围:在函数或类中定义的变量可以在该范围内的任何地方使用。...其余参数允许你将不同数量的参数(零个或多个)传递给函数。当你不确定函数将接收多少参数时,这很有用。其余符号之后的所有参数...都将存储在一个数组中。...Omit是实用程序类型的一种形式,它促进了常见的类型转换。Omit允许你通过传递电流Type并选择Keys在新类型中省略来构造类型。

    4.8K20

    30个小知识让你更清楚TypeScript

    它使用相同的范围规则,let并有助于降低整体程序的复杂性。 const num:number = 100; 10、在TypeScript中如何从子类调用基类构造函数?...你可以使用该super()函数来调用基类的构造函数。...这与JS相比如何? 全局作用域:在任何类之外定义,可以在程序中的任何地方使用。 函数/类范围:在函数或类中定义的变量可以在该范围内的任何地方使用。...其余参数允许你将不同数量的参数(零个或多个)传递给函数。当你不确定函数将接收多少参数时,这很有用。其余符号之后的所有参数...都将存储在一个数组中。...Omit是实用程序类型的一种形式,它促进了常见的类型转换。Omit允许你通过传递电流Type并选择Keys在新类型中省略来构造类型。

    3.6K20

    30道TypeScript 面试问题解析

    它使用相同的范围规则,let并有助于降低整体程序的复杂性。 const num:number = 100; 10、在TypeScript中如何从子类调用基类构造函数?...你可以使用该super()函数来调用基类的构造函数。...这与JS相比如何? 全局作用域:在任何类之外定义,可以在程序中的任何地方使用。 函数/类范围:在函数或类中定义的变量可以在该范围内的任何地方使用。...其余参数允许你将不同数量的参数(零个或多个)传递给函数。当你不确定函数将接收多少参数时,这很有用。其余符号之后的所有参数...都将存储在一个数组中。...Omit是实用程序类型的一种形式,它促进了常见的类型转换。Omit允许你通过传递电流Type并选择Keys在新类型中省略来构造类型。

    4.4K20

    了不起的 IoC 与 DI

    NestJS 中的应用; 了解如何使用 TypeScript 实现一个 IoC 容器,并了解 装饰器、反射 的相关知识。...比如你想更换汽车引擎的话,按照目前的方案,是实现不了的。 问题二:在汽车类内部,你需要在构造函数中手动去创建汽车的各个部件。...从上图可知,未使用依赖注入框架时,服务的使用者需要关心服务本身和其依赖的对象是如何创建的,且需要手动维护依赖关系。若服务本身需要依赖多个对象,这样就会增加使用难度和后期的维护成本。...4.2 使用依赖注入框架 使用依赖注入框架之后,系统中的服务会统一注册到 IoC 容器中,如果服务有依赖其他服务时,也需要对依赖进行声明。...最简单的情形是该类没有依赖其他对象,但在大多数场景下,即将实例化的服务类是会依赖其他的对象的。所以在实例化服务类前,我们需要构造其依赖的对象。 那么现在问题来了,怎么获取类所依赖的对象呢?

    2.7K30
    领券