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

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

Angular中的指令是什么? Angular的核心功能是指令,这些属性使您可以编写 特定于应用程序的新HTML语法。它们本质上是在Angular编译器在DOM中找到它们时执行的函数。...Angular中的service()是用于应用程序业务层的函数。它作为构造函数运行,并在运行时使用’new’关键字调用一次。...同样,应用程序的所有依赖关系通常仅在模块中定义。 26.我们可以在哪种类型的组件上创建自定义指令? Angular支持创建以下内容的自定义指令: 元素指令 -当遇到匹配的元素时,指令将激活。...为了更好地控制这些阶段,我们可以使用以下方法将其连接: 构造函数: 通过在类上调用new创建组件或指令时将调用它。...可以使用ng-hide指令与控制器一起轻松隐藏HTML元素,以在单击按钮时隐藏HTML元素。

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

    AngularDart Material Design 输入 顶

    它有可选的标签。注意:客户端必须在其指令列表中声明materialInputDirectives而不是MaterialInputComponent。...label String  此输入的标签。 如果没有在文本框中输入任何内容,则显示默认文本。当用户输入文本时,它会消失。...trailingGlyph String  在输入的后缘显示的任何符号 - 例如 URL链接图标或类似内容。...将此设置为true会更改行为,以便在更改选项或选项时:       1.选择中的第一个选定值在选项中有效       2.如果选择没有选定值,则选项中没有任何活动 inputText String...单击该图标将清除输入文本并隐藏弹出窗口。 showHintOnlyOnFocus bool  输入未聚焦时是否显示提示文本。 默认为false。

    6.9K40

    AngularDart 4.0 高级-生命周期钩子 顶

    生命周期序列 通过调用其构造函数创建组件/指令后,Angular在特定时刻按以下顺序调用生命周期钩子方法: 钩子 作用和时机 ngOnChanges Angular(重新)设置数据绑定输入属性时响应。...ngOnInit 在Angular首次显示数据绑定属性并设置指令/组件的输入属性后,初始化指令/组件。 在第一次ngOnChanges之后调用一次。...DoCheck 使用自定义更改检测实现ngDoCheck方法。 看看Angular多久会调用这个钩子,并在更改日志后观察它。 AfterView 通过视图显示Angular的意图。...peek-a-boo存在以显示Angular如何按预期顺序调用钩子。 此快照反映用户单击“创建...”按钮然后单击“销毁...”按钮后日志的状态。 ?...构造函数本身不是一个Angular钩子。 日志确认输入属性(在这种情况下的name属性)在构造时没有分配的值。

    7.6K10

    (转) 别再对 Angular 表单的 ControlValueAccessor 感到迷惑

    ,当 Angular 在组件模板中中遇到 input 或 textarea DOM 原生控件时,会使用DefaultValueAccessor 指令: @Component({ selector:...,包括上面代码中的 formControl 指令,都会调用 setUpControl 函数来让表单控件和DefaultValueAccessor 实现交互(译者注:意思就是上面代码中绑定的 formControl...指令,在其自身实例化时,会调用 setUpControl() 函数给同样绑定到 input的 DefaultValueAccessor 指令做好安装工作,如 L85,这样 formControl 指令就可以借助...组件封装器 由于 Angular 为所有默认原生控件提供了控件值访问器,所以在封装第三方插件或组件时,需要写一个新的控件值访问器。...在registerOnChange 里我们简单保存了对回调函数 fn 的引用,回调函数是由 formControl 指令传入的(译者注:参考 L85),只要每次 slider 组件值发生改变,就会触发这个回调函数

    4.8K20

    Angular源码分析之$compile

    @(Angular) $compile,在Angular中即“编译”服务,它涉及到Angular应用的“编译”和“链接”两个阶段,根据从DOM树遍历Angular的根节点(ng-app)和已构造完毕的...随后,在返回的compositeLinkFn中,则是遍历linkFns,针对每个链接函数,创建起对应的作用域对象(针对创建隔离作用域的指令,创建隔离作用域对象,并保存在节点的缓存中),并处理指令是否设置了...transclude属性,生成相关的transclude处理函数,最终执行链接函数;如果当前指令并没有链接函数,则调用其子元素的链接函数,完成当前元素的处理。...通过compileNodes返回从根节点(ng-app所在节点)开始的所有指令的最终合成链接函数,最终在publicLinkFn函数中执行。...在publicLinkFn中,完成根节点与根作用域的绑定,并在根节点缓存指令的控制器实例,最终执行合成链接函数,完成了Angular最重要的编译,链接两个阶段,从而开始了真正意义上的双向绑定。

    1.7K50

    再谈angularJS数据绑定机制及背后原理—angularJS常见问题总结

    循环 新的 $digest 循环未检测到变化 浏览器拿回控制器,更新 $scope. val.新值对应的 dom 在调用了$scope....假设你在一个ng-click指令对应的handler函数中更改了scope中的一条数据,此时AngularJS会自动地通过调用$digest()来触发一轮$digest循环。...angularjs里比较重要但又很少手动调用的要属$compile服务了,通常在写组件或指令时,都是angularjs自动编译完成的,但有时我们可能需要手动编译,比如封装一个table组件,根据参数实现自定义渲染...$compile,在Angular中即“编译”服务,它涉及到Angular应用的“编译”和“链接”两个阶段,根据从DOM树遍历Angular的根节点(ng-app)和已构造完毕的 \$rootScope...对象,依次解析根节点后代,根据多种条件查找指令,并完成每个指令相关的操作(如指令的作用域,控制器绑定以及transclude等),最终返回每个指令的链接函数,并将所有指令的链接函数合成为一个处理后的链接函数

    9.3K40

    IntelliJ IDEA 2022.2.2汉化版免登陆账号「winmac」

    -改进了Stream API支持在IntelliJ IDEA 中,我们改进了对Stream API的支持,因此它现在可以检测收集未排序集合的已排序流。...对于每个更改列表,IDE将在新的“ 合并冲突”节点下对此类文件进行分组。单击“ 解决操作”链接以打开“ 与冲突合并的文件”对话框。...6、组态- 项目配置在IntelliJ IDEA 中,您可以在添加新存储库时排除某些传递依赖项。单击库属性编辑器中的新配置操作链接。...- 与Angular CLI的新集成在IntelliJ IDEA 2019中,由于与ng add的集成,您可以为Angular应用程序添加新功能。...您可以通过从过程的上下文菜单中选择“ 执行”操作来运行过程,也可以在打开源代码时单击工具栏中的“运行”按钮来运行过程。

    6.2K30

    Angular6自定义表单控件方式集成Editormd

    曾经找到过“Editor.md”,看之心喜,一直想在Angular中集成下这款markdownpad编辑器玩,在网上也只找到一篇通过指令集成的,虽然可以实现,但还是希望能做成组件形式的,之后看到一篇自定义组件的文章...(isDisabled: boolean): void; } writeValue:在初始化的时候将formControl的值传递给原生表单控件(即,将模型中的新值写入视图或 DOM 属性中); registerOnChange...:用来获取原生表单控件的值更新时通知Angular表单控件更新的函数(即,设置当控件接收到 change 事件后,调用的函数) registerOnTouched:用来获取通知用户正在交互的函数(即,设置当控件接收到...touched 事件后,调用的函数)。...(isDisabled: boolean):设置DISABLED状态时做的执行的方法。即,当控件状态变成 DISABLED 或从 DISABLED 状态变化成 ENABLE 状态时,会调用该函数。

    5.9K20

    AngularDart 4.0 高级-路由概述 顶

    它可以将浏览器URL解释为导航到客户端生成视图的指令。它可以将可选参数传递给支持视图组件,以帮助确定要呈现的具体内容。您可以将路由器绑定到页面上的链接,并在用户单击链接时导航到适当的应用程序视图。...当用户点击按钮,从下拉框中选择,或者响应来自任何来源的其他刺激时,您都可以进行命令式导航。并且路由器在浏览器的历史记录中记录活动,所以后退和前进按钮也起作用。...在任何使用路由器功能的Dart文件中,导入路由器库: import 'package:angular_router/angular_router.dart'; 注册提供者和列表指令 如果您已经熟悉Angular...RouterLink指令还有助于在视觉上区分当前所选活动路线的锚点。当关联的路由链接变为活动状态时,路由将router-link-active CSS类添加到元素。...单击具有绑定到链接参数列表的routerLink指令的元素会触发导航。 Link parameters list 路由将其解释为路由指令的列表。

    7.7K20

    教程|在 Angular 4 中加载功能模块(上)

    请注意,本教程适用于熟悉使用 Angular 进行基本 Web 应用程序开发的开发人员。 Angular 中的功能模块 单页 Web 应用程序在启动时仅呈现一个 HTML 页面。...一个 Angular 应用程序由以下部分组成: 模块 组件 模板 元数据 数据绑定 指令 服务 依赖注入 每个 Angular 应用程序都至少有一个模块,称为根模块。...预加载:在预加载场景中,主应用程序启动所有标为贪婪加载的模块,然后几乎立即在后台加载 。当用户导航到这些辅助模块中的某个模块时,就会加载该模块并准备就绪。...用户单击 Markets 链接时,应用程序会调用 /markets 路径。用户单击 Sports 链接时,应用程序会调用 /sports 路径。 图 5....图 6. app-routing.module.ts 在调用 /markets 和 /sports 路径时,会调用 MarketComponent 和 SportsComponent。

    3K10

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

    一个组件控制屏幕中的一小块视图。 例如,以下视图由组件控制: 与导航链接的应用程序根。 英雄名单。 英雄编辑 您可以在一个类中定义一个组件的应用程序逻辑 - 它支持视图的功能。...自定义组件与原生HTML在相同的布局中无缝混合。 元数据 ? 元数据告诉Angular如何处理一个类。 回顾HeroListComponent的代码,你可以看到它只是一个类。...当用户点击英雄的名字时,(click)事件绑定调用组件的selectHero方法。 双向数据绑定是一个重要的第四种形式,它使用ngModel指令将属性和事件绑定在一个符号中。...当Angular呈现它们时,它根据指令给出的指示转换DOM。 指令是一个带有@Directive注解的类。...如果请求的服务实例不在容器中,那么在将服务返回给Angular之前,注入器将创建一个并将其添加到容器中。 当所有请求的服务已经解析并返回时,Angular可以用这些服务作为参数调用组件的构造函数。

    9.5K30

    AngularDart4.0 英雄之旅-教程-07路由 顶

    RouterLink指令告诉路由在用户点击链接时的位置。 您使用链接参数列表定义了一个路由指令, 这个列表在我们的小样本中只有一个元素,引用的路由名称。...在构造函数中注入HeroService,并将其保存在一个专用的_heroService字段中。 调用服务来获取Angular ngOnInit()生命周期钩子中的英雄。...你已经完成了应用程序的路由。 您没有向模板添加英雄详情链接,因为用户单击导航链接不是为了查看特定的英雄; 而是点击一个英雄的名字,不管名字是显示在仪表板还是英雄列表中。...要在其他地方导航,用户可以单击AppComponent中的两个链接之一,或单击浏览器的后退按钮。...在构造函数中注入路由器,以及HeroService。 通过调用路由器的navigate()方法来实现gotoDetail()。

    19.4K30

    如何使用WijmoJS 纯前端设计器,快速生成 Angular 应用

    在HTML文件中,它在代表WijmoJS纯前端控件的每个标记上方插入CodeLens链接。单击该链接可在单独的选项卡中打开Wijmo Designer,并根据关联的标记对其进行初始化。...WijmoJS VSCode Designer还提供了一个独立的命令,可以在单独的选项卡中打开设计图面,您可以在其中使用示例数据实例化控件,自定义其属性,并生成可以复制到源文件中的Angular标记。...在我们的示例中,操作是在单独的选项卡中打开设计图面,并使用 Angular标记提供的上下文,以及源文件中该标记的位置。 现在单击链接以在相邻选项卡中打开设计器。...但是,您应该知道扩展会记住调用它的Angular标记的文档范围。 如果随后修改了原始源文件,则应重新访问CodeLens链接以刷新关联的设计器选项卡。...设计器版本之间的差异 下表总结了WijmoJS 可视化在线设计器,从HTML源文件中的CodeLens链接调用和VS Code从独立命令调用 WijmoJS VSCode设计器之间的差异: 设计器不提供

    7K40

    Angular快速学习笔记(3) -- 组件与模板

    显示数据 在 Angular 中最典型的数据显示方式,就是把 HTML 模板中的控件绑定到 Angular 组件的属性。...属性, 在组件元数据中把它链接到组件 到底选择内联 HTML 还是独立 HTML 取决于个人喜好、具体状况和组织级策略。...通常,指令使用 Angular EventEmitter 来触发自定义事件。...Angular 管道对像这样的小型转换来说是个明智的选择。 管道是一个简单的函数,它接受一个输入值,并返回转换结果。 它们很容易用于模板表达式中,只要使用管道操作符 (|) 就行了。...在 Angular 销毁指令/组件之前调用 OnInit钩子 使用 ngOnInit() 有两个原因: 在构造函数之后马上执行复杂的初始化逻辑 在 Angular 设置完输入属性之后,对该组件进行准备

    16.6K30

    带你走近AngularJS - 基本功能介绍

    了解AngularJS的开发人员,你肯定会为AngularJS自定义指令(它的功能相当于.NET 平台下的自定义控件)功能感到兴奋。自定义指令允许你扩展HTML标签和特性。...所以,Wijmo是学习AngularJS很好的参考示例:AngularJS Directive Gallery ? 创建自定义指令是非常容易的。指令可以测试、维护并且在多个项目中复用。...controller 构造函数获取$scope 对象,用于存储所有controller 暴露的接口和方法。scope 由Angular 传递到视图和指令层。...filter 构造函数返回一个方法用于更改input文本的显示方式。Angular 提供很多内置的filter,同时,你也可以添加自定义filter,操作方式Angular内置filter相同。...", []); 如果希望在模块中添加元素,你可以通过名称调用模块向其中添加。

    3.6K100
    领券