时间:2021-05-28
组件
使用命令创建组件
•创建组件的命令:ng generate component 组件名
•生成的组件组成: 组件名.html 、组件名.ts、组件名.less、组件名.spec.ts
•在组件的控制器
手动创建组件
1.创建一个组件ts文件
2.在组件中设置
1.在index.ts文件中引入并导出
// 1. 导入import { DinerBirthComponent } from "./diner.birth";// 2. 导出export { DinerBirthComponent }// 3. 注册@NgModule({ // 这里列出的 NgModule 所导出的可声明对象可用在当前模块内的模板中 imports: [....], // declarations:[ 组件 ] 属于该模块的一组组件、指令和管道(统称可声明对象)。 // 注意点:在这个源数据中只能声明组件、管道、指令 declarations: [DinerBirthComponent], // 定义此 NgModule 中要编译的组件集,这样它们才可以动态加载到视图中。 entryComponents: [....], // 导出的模块 exports: [....]})指令
认识指令
•说明:在 Angular 中有三种类型的指令: ◦1.组件 — 拥有模板的指令
◦2.结构型指令 — 通过添加和移除 DOM 元素改变 DOM 布局的指令
◦3.属性型指令 — 改变元素、组件或其它指令的外观和行为的指令。
自定义指令
•创建自定义指令的命令: ng g d 目录/指令名称
•创建指令
1.创建指令的文件ts文件
2.在指令文件中写
import { Directive, ElementRef, Input, Output } from '@angular/core';// 自定义指令@Directive({ selector: '[dinerHidden]'})// 导出指令的模块export class DinerHiddenDirective { // el 代表当前的元素 constructor(el: ElementRef) { // console.log() el.nativeElement.style.display = "none" }}1.在index.ts中将该指令导入到ngModule中// 1.导入import { DinerHiddenDirective } from "./diner.hidden";// 2.导出export const DINER_COMPONENTS: Provider[] = [ DinerHiddenDirective ];// 3.ngModule中注册@NgModule({ // 这里列出的 NgModule 所导出的可声明对象可用在当前模块内的模板中 imports: [], // declarations:[ 组件 ] 属于该模块的一组组件、指令和管道(统称可声明对象)。 // 注意点:在这个源数据中只能声明组件、管道、指令 declarations: [DINER_COMPONENTS], // 定义此 NgModule 中要编译的组件集,这样它们才可以动态加载到视图中。 entryComponents: []})1.在页面中引用
<!-- 隐藏当前的这个标签 --> <div class="form-group col-sm-6" dinerHidden> </div>管道中的常用API
asyncPipe
•说明:async 管道会订阅一个 Observable 或 Promise,并返回它发出的最近一个值。 当新值到来时,async 管道就会把该组件标记为需要进行变更检测。当组件被销毁时,async 管道就会自动取消订阅,以消除潜在的内存泄露问题。
CurrencyPipe
•说明:把数字转换成金额字符串, 根据本地化规则进行格式化,这些规则会决定分组大小和分组分隔符、小数点字符以及其它与本地化环境有关的配置项。
DatePipe
•说明:把数字转换成金额字符串, 根据本地化规则进行格式化,这些规则会决定分组大小和分组分隔符、小数点字符以及其它与本地化环境有关的配置项。
DecimalPipe
•说明:把数字转换成字符串, 根据本地化规则进行格式化,这些规则会决定分组大小和分组分隔符、小数点字符以及其它与本地化环境有关的配置项。
自定义管道
•创建管道的命令:ng g pipe 目录/管道名称
•手动创建管道 •创建ts文件
import { Pipe, PipeTransform } from '@angular/core';// 自定义管道 getGender@Pipe({ name: 'getGender'})// 创建的管道的类export class GenderPipe implements PipeTransform { transform(value: string, exponent: string) { if (value == ' ') return "未知" return value === 'm' ? "男" : "女" }}•将这个管道添加到NgModuel中
// 1. 先导入import { GenderPipe } from "./diner.gender";// 2.导出 export const DINER_COMPONENTS: Provider[] = [GenderPipe];// 3.添加到NgModule中的@NgModule({ // 这里列出的 NgModule 所导出的可声明对象可用在当前模块内的模板中 imports: [...], // declarations:[ 组件 ] 属于该模块的一组组件、指令和管道(统称可声明对象)。 // 注意点:在这个源数据中只能声明组件、管道、指令 declarations: [DINER_COMPONENTS], // 定义此 NgModule 中要编译的组件集,这样它们才可以动态加载到视图中。 entryComponents: [...]})•在页面中引入使用
总结
以上所述是小编给大家介绍的Angular7中创建组件/自定义指令/管道的方法实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文给大家分享angular.js学习笔记之自定义指令实例代码讲解,具体代码如下所示:AngularDirective/*Angular.js自定义指令的格式和
本文实例讲述了AngularJS实现自定义指令与控制器数据交互的方法。分享给大家供大家参考,具体如下:AngularJS自定义指令与控制器数据交互angular
本文实例讲述了AngularJS自定义指令之复制指令实现方法。分享给大家供大家参考,具体如下:varapp=angular.module('myapp',[])
本文实例讲述了vue自定义指令的创建和使用方法。分享给大家供大家参考,具体如下:一、自定义指令的创建和使用Vue自带的指令很多,v-for/v-if/v-els
下面给大家分享vue自定义指令拖拽功能代码,具体代码如下所示:实例方法//自定义指令Vue.directive('drag',function(){varoDi