Angular入门到精通系列教程(7)- 组件(@Component)基本知识[email protected] angular_Jack N的博客-程序员秘密

技术标签: angular  Angular入门到精通  Angular  

环境:

  • Angular CLI: 11.0.6
  • Angular: 11.0.7
  • Node: 12.18.3
  • npm : 6.14.6
  • IDE: Visual Studio Code

1. 概述

组件是 Angular 应用的主要构造块。每个组件包括如下部分:

  • 一个 HTML 模板,用于声明页面要渲染的内容
  • 一个用于定义行为的 Typescript 类
  • 一个 CSS 选择器,用于定义组件在模板中的使用方式
  • (可选)要应用在模板上的 CSS 样式

Component可以是一个页面,也可以是一个组件(控件)。总是,是一个页面元素。

任何一个Component都是NgModule的一部分,这样它就可以被其他应用和其他Component所调用。为了定义Component是NgModule的一个成员之一,开发者应该在NgModule的declarations属性中,将自己开发的Component列出。

另外,通过Component修饰符(也就是@Component)开发者可以配置元数据,这样通过各式各样的Life-Cycle hooks,Components就可以控制他们的运行环境。

2. 创建Component

基于AngularCLI,可以很方便的创建Component。在要创建Component的目录下,执行如下命令

ng generate component <component-name> 

e.g. ng generate component MyComponent
AngularCLI会自动生成一个文件夹和4个文件:

  • 一个以该组件命名的文件夹(e.g my-component)
  • 一个组件文件 < component-name >.component.ts(e.g my-component.component.ts)
  • 一个模板文件 < component-name >.component.html(e.g my-component.component.html)
  • 一个 CSS 文件, < component-name >.component.css(e.g my-component.component.css)
  • 测试文件 < component-name >.component.spec.ts(e.g my-component.component.spec.ts)

对于Component,所有文件名都会自动增加Component后缀,所以不建议< component-name > 中带有‘component’这个单词。

@Component({
    
  selector: 'app-my-component',
  templateUrl: './my-component.component.html',
  styleUrls: ['./my-component.component.css']
})
export class MyComponentComponent implements OnInit {
    

  constructor() {
     }

  ngOnInit(): void {
    
  }

}

以上是核心的ts文件,指定了selector(CSS 选择器),template(html)文件,css文件。html/css文件如果需要可以多个component公用。尤其是css,可以看到参数是Array,所以可以制定多个css。

2.1. 组件模板

组件模板,即HTML部分,可以是一个html文件,也可以是一段html描述,是等价的。Angular 组件需要一个用 template 或 templateUrl 定义的模板。但你不能在组件中同时拥有这两个语句。

  1. html 文件方式
@Component({
    
  selector: 'app-component-overview',
  templateUrl: './component-overview.component.html',
})
  1. html代码方式
@Component({
    
  selector: 'app-component-overview',
  template: '<h1>Hello World!</h1>',
})

3. 视图封装模式

在 Angular 中,组件的 CSS 样式被封装进了自己的视图中,而不希望影响到应用程序的其它部分。这部分也是可以通过配置去进行控制的。

@Component({
    
  selector: 'app-my-component',
  templateUrl: './my-component.component.html',
  encapsulation: ViewEncapsulation.None,
  styleUrls: ['./my-component.component.css']
})

可以看到,增加了一个encapsulation属性 (视图封装模式)。通过在组件的元数据上设置视图封装模式,你可以分别控制每个组件的封装模式。 可选的封装模式一共有如下几种:

  1. Emulated 模式(默认值)通过预处理(并改名)CSS 代码来模拟 Shadow DOM 的行为,以达到把 CSS 样式局限在组件视图中的目的。 更多信息,见附录 1。(说明:只进不出,全局样式能进来,组件样式出不去)
  2. ShadowDom 模式使用浏览器原生的 Shadow DOM 实现来为组件的宿主元素附加一个 Shadow DOM。组件的视图被附加到这个 Shadow DOM 中,组件的样式也被包含在这个 Shadow DOM 中。(说明:不进不出,没有样式能进来,组件样式出不去。)
  3. None 意味着 Angular 不使用视图封装。 Angular 会把 CSS 添加到全局样式中。而不会应用上前面讨论过的那些作用域规则、隔离和保护等。 从本质上来说,这跟把组件的样式直接放进 HTML 是一样的。

3.1. 特殊的选择器 :host

使用 :host 伪类选择器,用来选择组件宿主元素中的元素(相对于组件模板内部的元素)。 :host 选择是是把宿主元素作为目标的唯一方式。除此之外,你将没办法指定它, 因为宿主不是组件自身模板的一部分,而是父组件模板的一部分。

e.g.

:host {
    
}

3.2. inline-styles

默认AngularCLI生成的component,css在一个单独文件中。当然,同html模板类似,如果需要,你也可以制定css样式写在ts中, 不单独放到一个文件中。命令:ng generate component MyComponent --inline-style

生成component如下

@Component({
    
  selector: 'app-my-component',
  template: '<h1>Hello World!</h1>',
  styles: ['h1 { font-weight: normal; }']
})

4. 总结

  • Angular CLI辅助创建一个component所需的多个文件
  • 建议html/css/ts分开
  • 在期望目录下执行Angular CLI命令,可以生成到制定目录
  • ng generate component XXX 可以简写为 ng g c



---------------- END ----------------






======================

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_43288714/article/details/112525183

智能推荐

2017-09-16 前端日报_weixin_33904756的博客-程序员秘密

2017-09-16 前端日报精选深入理解 js this 绑定请使用千位分隔符(逗号)表示web网页中的大数字跨页面通信的各种姿势你所不知道的 CSS 滤镜技巧与细节代码质量管控 -- 复杂度检测On React and WordPress3D Face Reconstruction中文『翻译』基于 Vue.js 与 Webpa...

ubuntu安装wpscan_李小怪的博客-程序员秘密

ubuntu没有用kali的源,所以上wpscan的官网去下最新版。https://wpscan.org/首先要安装依赖。PrerequisitesRuby >= 2.1.9 - Recommended: 2.3.3Curl >= 7.21 - Recommended: latest - FYI the 7.29 has a segfaultRubyGems - Recom

CCF-201709-4-通信网络_AivenZ的博客-程序员秘密

这道题爆搜,每个结点作为起点开始搜,每搜到一个,就标记一个。用一个邻接矩阵knows来标记得到联系的点。比如从点1开始搜,搜到4,那就 knows[1][4] = knows[4][1] = 1。结点数不多,所以可以爆搜,但是没想到同样的思路java可以100,python就只有75,真的玄学。。。平时用python做题,内存,运行时间都比java好的。Java代码import java.u...

echarts 使用 time 时间轴_echarts时间轴_我能做的就是尽量向诗靠拢的博客-程序员秘密

最少代码量表达:let myChart = this.$echarts.init(document.getElementById('myEcharts')); // 绘制图表 let option; option = { xAxis: { type: 'time', }, yAxis: { type: 'value', }, series: [ { type: 'line', data: [ [

对网页的相关操作_weixin_30636089的博客-程序员秘密

对网页的相应操作登录到163网站,保存下来首页Type "help", "copyright", "credits" or "license" for more information.&gt;&gt;&gt; import urllib&gt;&gt;&gt; url='http://www.163.com'&gt;&gt;&gt; content=urllib.urlopen(url...

微信小程序模拟器所有页面都无法跳转_微信小程序模拟器页面不改变_敲代码的作家的博客-程序员秘密

习惯性晚上不关电脑,早上可以不用打开开发工具继续开发,今天一打开微信小程序所有页面都不能进行跳转,百度了一下说是页面栈的问题,思考后倒没发现有这方面的问题,还以为是缓存问题,因为真机调试没有问题。解决方法:重启开发者工具。微信开发者工具只要不关闭第二天总会出现问题,不是卡死就是别的各种问题,所以还是尽量工作完后关闭电脑。...

随便推点

成就系统工程师的职业生涯_iteye_482的博客-程序员秘密

题外话从家长到老师、从学生到职场精英,每个人都在说中国是应试教育,不是素质教育;中国是发展中国家,没有职业市场,一个人能成就什么,靠的是运气、胆量而不是技能、创造力。是这样么?历史有惊人的相似性,一句最具代表性的名言是:这个世界最不可思议的事情是它能够被人理解。同样的事情,在世界上的发达国家、在地球的其他角落,曾经发生或者正在发生,也可能即将发生。作为一名中国人,非常骄傲于中国近三十年来取得的...

C#接口与抽象类的区别_c接口与抽象类的区别_小怪兽^你欠的博客-程序员秘密

C#基础知识,接口和抽象类,整理总结,学习笔记

GPIO_ReadInputDataBit_weixin_30550271的博客-程序员秘密

今天发现了一个很有意思的问题用 GPIO_ReadInputDataBit 去读I/O口的电平,I/O口上拉,如果将IO口初始化成上拉输入,则不管是否短接GND,读的结果都是高电平,设置成浮空输入也一样只有将IO口设置成下拉输入,才可以用 GPIO_ReadInputDataBit 函数读到正确的电平状态。转载于:https://www.cnblogs.com/fly...

Alluxio使用场景_卡奥斯道的博客-程序员秘密

详见:http://blog.csdn.net/alluxio/article/details/59536999特点:多个Spark job以内存级速度共享相同的数据(可以做到多个job共享一个RDD)

LeetCode95. 不同的二叉搜索树 II_秋刀鱼98的博客-程序员秘密

LeetCode95. 不同的二叉搜索树 II给定一个整数 n,生成所有由 1 … n 为节点所组成的 二叉搜索树 。输入:3输出:[ [1,null,3,2], [3,2,null,1], [3,1,null,null,2], [2,1,3], [1,null,2,null,3]]解释:以上的输出对应以下 5 种不同结构的二叉搜索树: 1 3 3 2 1 \ / / / \

php判断闰年的三种方法(闰年计算方法)_php三元运算符判断闰年_helin916012530的博客-程序员秘密

1,php闰年计算方法一:①、普通年能被4整除而不能被100整除的为闰年。(如2004年就是闰年,1900年不是闰年) ②、世纪年能被400整除而不能被3200整除的为闰年。(如2000年是闰年,3200年不是闰年)$year=mt_rand(1900,2200);//从1900年到2200,可以自己改,也可以给一个定值。if($year%100==0){//判断世纪年if ($y

推荐文章

热门文章

相关标签