Angular6 学习笔记——组件详解之模板语法
angular6.x系列的学习笔记记录,仍在不断完善中,学习地址:
系列目录
(1)组件详解之模板语法
(2)组件详解之组件通讯
(3)内容投影, ViewChild和ContentChild
(4)指令
(5)路由
章节目录
1插值语法和表达式
2在模板内部定义变量
3值绑定,事件绑定,双向绑定
4内置结构型指令*ngIf,*ngFor,ngSwitch
5内置属性型指令:NgClass,NgStyle
6管道与安全导航
7导入Bootstrap和fontawesome
Angular在模板引擎里面对这些最基本的东西做了很强的支持,所以它的模板表达能力是非常强的
1插值语法和表达式
类似前端模板引擎handlebars等的语法
能够插入定义的变量,简单的加减乘除等数学运算和调用方法
<p>定义的变量:{{str}}</p>
<p>简单数学运算:1+1={{1+1}}</p>
<p>调用方法:{{getValue()}}</p>
2在模板内部定义变量
我们既可以在组件内部定义变量,也可以模板内部定义变量
通过#自动生成一个局部变量,给标签命名,可以在组件内部和模板内部传递
<input #inputVal>
<p>{{inputVal.value}}</p>
<button class="btn btn-success" (click)="print(inputVal.value)">打印</button>
3值绑定,事件绑定,双向绑定
值绑定
在模板内部,一些标签的某些属性不是固定的,会根据不同的情形变化,例如照片的src属性,
我们可以通过值绑定(用[]表示),将它绑定到变量上,随着变量值的改变而改变
事件绑定
在模板内部,某些操作会触发事件,例如点击按钮
我们可以通过事件绑定(用()表示),将它绑定到指定事件上
<img [src]="imgSrc" />
<button (click)="changeImgSrc()">
将事件changeImgSrc()绑定到button上来,
修改imgSrc变量的值,改变img标签通过值绑定的src属性的值
</button>
双向绑定
什么是双向绑定呢?指的是界面的操作能实时反映到数据,数据的变更能实时展现到界面。
双向绑定用[()]来表示,常见的双向绑定有NgModel,它仅用于表单类元素上面
<input [(ngModel)]="str">
<p>{{str}}</p>
<button (click)="changeStr()"></button>
组件内部修改数据能够实时反应到界面,界面上的修改也能实时传递到组件内部
4内置结构型指令*ngIf,*ngFor,ngSwitch:
*ngIf
在模板内部来判断元素是否存在,它不是用display:none或者class=hide等显示隐藏的方式,而是直接删除,所以为真即存在,为假即删除
它既可以是已经定义的变量,也可以是语句
<p *ngIf="1>=2">为false不显示</p>
<p *ngIf="isShow">变量控制是否显示</p>
*ngFor
作用如其名,用于遍历数组
<ul>
<li *ngFor="let item of arr;let i=index;">
{{i+1}}:{{item.value}}
</li>
</ul>
ngSwitch
神似其他语言里面的条件语句switch case,代码如下
<span [ngSwitch]="num">
<span *ngSwitchCase="'1'">值为1</span>
<span *ngSwitchCase="'2'">值为2</span>
<span *ngSwitchCase="'3'">值为3</span>
<span *ngSwitchCase="'4'">值为4</span>
<span *ngSwitchCase="'5'">值为5</span>
<span *ngSwitchDefault>默认值10</span>
</span>
5内置属性型指令:NgClass,NgStyle
NgClass和NgStyle都是用来通过代码控制标签样式
NgClass
得先写好样式文件,通过代码切换不同的样式
<p [ngClass]="{'special':true}">用NgClass添加样式类</p>
special是已经写好的样式类
NgStyle
不需要先写好样式文件,能够细节的去处理样式
<p [ngStyle]="{'color':1>2?'red':'blue'}">用NgStyle控制内联样式</p>
<div [ngStyle]="{'background-image': 'url('+x.ImgUrl+')','width':'100%','height':'120px','background-size':'cover'}">
6管道与安全导航
管道
当我们有数据需要做格式转换的时候,管道是很好的选择,因为它速度快,能复用
管道符号用|表示,例如x | y,把x作为参数传到y中处理,当然可以 x | y | z,它能够级联使用
例如时间的处理
<p>{{currentTime | date:'yyyy-MM-dd HH:mm:ss'}}</p>
安全导航
很多时候我们在使用某个对象变量的时候,如果这个对象为null或者undefined,当我们直接点它下面的属性,就会报错
对于这种情况,常用的解决方法是三元操作,先判断一下这个对象
相比于三元操作,有更加优秀的解决方法
<p>{{Obj?.value}}</p>
它会先判断Obj,如果为null或者undefined,不会直接报错
7 导入Bootstrap和fontawesome
首先在配置文件package.json dependencies下添加依赖的模块
"bootstrap": "^3.3.7",
"font-awesome": "^4.7.0",
然后在src文件夹下的style文件里面添加
@import "~bootstrap/dist/css/bootstrap.min.css";
@import "~font-awesome/css/font-awesome.min.css";
这样就可以在模板内部使用它们了
(终)
文档信息
- 发表作者: 半路独行
- 发表出处: 博客园
- 原文地址: https://www.cnblogs.com/banluduxing/p/9290208.html
- 版权信息:
本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。
感谢您的阅读,如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮。本文欢迎各位转载,但是转载文章之后必须在文章页面中给出作者和原文连接。
Angular6 学习笔记——组件详解之模板语法的更多相关文章
- Angular6 学习笔记——组件详解之组件通讯
angular6.x系列的学习笔记记录,仍在不断完善中,学习地址: https://www.angular.cn/guide/template-syntax http://www.ngfans.net ...
- Angular6 学习笔记——路由详解
angular6.x系列的学习笔记记录,仍在不断完善中,学习地址: https://www.angular.cn/guide/template-syntax http://www.ngfans.net ...
- Android学习笔记-Dialog详解
1.对话框的使用 1.1AlertDialog的显示 简单对话框以及监听的设置:重点掌握三个按钮(也就是三上单词): PositiveButton(确认按钮);NeutralButton(忽略按钮) ...
- JavaScript学习笔记-实例详解-类(二)
实例详解-类(二) //===给Object.prototype添加只读\不可枚举\不可配置的属性objectId(function(){ Object.defineProperty(Object ...
- JavaScript学习笔记-实例详解-类(一)
实例详解-类(一): //每个javascript函数(除了bind())都自动拥有一个prototype对象// 在未添加属性或重写prototype对象之前,它只包含唯一一个不可枚举属性const ...
- C++并发与多线程学习笔记--unique_lock详解
unique_lock 取代lock_quard unique_lock 的第二个参数 std::adopt_lock std::try_to_lock std::defer_lock unique_ ...
- [CSS3] 学习笔记-选择器详解(三)
1.UI元素状态伪类选择器 在CSS3的选择器中,除了结构性伪类选择器外,还有一种UI元素伪类选择器.这些选择器的共同特征是:指定的样式只有当元素处于某种状态时才起作用,在默认状态下不起作用.在CSS ...
- [CSS3] 学习笔记-选择器详解(二)
1.选择器first-child.last-child.nth-child和nth-last-child 利用first-child.last-child.nth-child和nth-last-chi ...
- Linux学习笔记之详解linux软连接和硬链接
0x00 链接文件 Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link).默认情况下,ln命令产生硬链接. [软连接] 另外一种连接称之为符 ...
随机推荐
- 【英宝通Unity4.0公开课学习 】(一)资源管理
经过多次面试后发现自己对Unity3D的框架缺乏一个整体的认识. 而前面由于离职等原因总是忙于修修补补,疲于奔命,感觉相当疲惫. 还好,后来经过调整,开始淡定了起来.得特别感谢一本书哇:<高效人 ...
- Pie(浮点数二分)
Pie http://poj.org/problem?id=3122 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2454 ...
- 解决SpringBoot中webScocket不能注入bean的问题
最近在做websocket聊天,但是遇到一个问题,就是在websocket的服务中要调用Service层的东西.首先我想到的是通过@Autowire注解来实现bean的注入.但是进过测试发现,注入的b ...
- iis 应用程序连接池 在计算机“.”上没有找到WAS服务
重新打开控制面板----打开或关闭windows功能,全部勾选internet information services 可承载的web核心. internet信息服务.microsoft.net f ...
- Excel单元格内容批量加前缀
比如83190001在A1单元格,要在A列单元内容前面批量加0,在B1输入公式="0"&A1然后向下复制再把B列复制的结果再复制一下:然后到新的一列粘贴,在“粘贴选项”中选 ...
- MySql中循环的使用
一.while循环 语法:WHILE [条件] DO [逻辑] END WHILE; delimiter $$ DROP FUNCTION IF EXISTS `fn_findCharCount` $ ...
- MEME(Motif-based sequence analysis tools)使用说明
MEME(Motif-based sequence analysis tools)使用说明 2011-05-27 ~ ADMIN MEME是用于从一堆序列中搜索功能结构域的工具.比如说当你拿到了许多C ...
- 用pyqt5做一个能python程序能插入图片的ide
之前只是放到github上了,现在一想应该开源,大家想继续做好这个ide的都能从这里起步. #注意在.py文件相同目录下放一个1.png做测试图片 #本质就是用html来实现图片 #写在前面的话:这个 ...
- C山寨C++
#include <stdio.h> #include <string.h> #include <malloc.h> typedef struct Aclass_s ...
- ubuntu系统下安装pyspider:搭建pyspider服务器新手教程
首先感谢“巧克力味腺嘌呤”的博客和Debian 8.1 安装配置 pyspider 爬虫,本人根据他们的教程在ubuntu系统中进行了实际操作,发现有一些不同,也出现了很多错误,因此做此教程,为新手服 ...