angular4.x 创建组件、绑定数据、绑定属性、 数据循环、条件判断、事件、表单处理、双 向数据绑定

一、创建 angualr 组件

ScaffoldUsage
Component

ng g component my-new-component

指定目录创建 :ng g component components/Footer

Directiveng g directive my-new-directive
Pipeng g pipe my-new-pipe
Serviceng g service my-new-service
Classng g class my-new-class
Guardng g guard my-new-guard
Interfaceng g interface my-new-interface
Enumng g enum my-new-enum
Moduleng g module my-module

创建组件

ng g component components/header

使用组件:

<app-header></app-header>

二、angualr4.0 绑定数据

1. 数据文本绑定 {{}}

<h1> {{title}}</h1>

2.绑定 html

this.h="<h2>这是一个 h2 用[innerHTML]来解析</h2>"

<div [innerHTML]="h"></div>

三、数据循环 *ngFor

1、*ngFor 普通循环

<ul>

<li *ngFor="let item of list"> {{item}}</li>

</ul>

2、循环的时候设置 key

<ul>

    <li *ngFor="let item of list;let i = index;"> {{item}} --{{i}}</li>

</ul>

3、template 循环数据

<ul>

     <li template="ngFor let item of list">

        {{item}}

     </li>

</ul>

四、条件判断 *ngIf

<p *ngIf="list.length > 3">这是 ngIF 判断是否显示</p>

<p template="ngIf list.length > 3">这是 ngIF 判断是否显示</p>

五、执行事件 (click)=”getData()”

<button class="button" (click)="getData()"> 点击按钮触发事件</button>

<button class="button" (click)="setData()">

  点击按钮设置数据

</button>

getData(){ /*自定义方法获取数据*/ //获取

alert(this.msg);

}

 getData(){ /*自定义方法获取数据*/ //获取

   alert(this.msg);

}

//设置值

setData(){

   this.msg = "这是设置的值"

}

六、绑定属性

<div [id]="id" [title]="msg">调试工具看看我的属性</div>

<div _ngcontent-c1 id = "123" title = "你好angular4.0"></div>

七、表单处理

<input type="text" (keyup)="keyUpFn($event)"/>

<input type="text" (keyup)="keyUpFn($event)"/>

keyUpFn(e){

 console.log(e);

}

八、双向数据绑定

<input [(ngModel)]="inputValue">

注意引入:FormsModule

import { FormsModule } from '@angular/forms'

@NgModule({

declarations: [

AppComponent,

HeaderComponent,

FooterComponent,

NewsComponent

],

imports: [

BrowserModule,

FormsModule

],

providers: [],

bootstrap: [AppComponent]

})

export class AppModule { }

使用:

<input type="text" [(ngModel)]="inputValue"/>{{inputValue}}

九、Todolist 功能

html 代码

<input type="text" [(ngModel)]='username'>

<button (click)='addData()'>增加</button>

<ul>

   <li *ngFor="let item of list">

     {{item}}

   </li>

</ul>

Js 代码

export class TodolistComponent implements OnInit {

list:any[];

username:any;

constructor() { }

ngOnInit() {

this.list=[]; this.username='';

}

addData(){

alert(this.username);

this.list.push(this.username);

}

}

1、ngStyle

基本用法

<div [ngStyle]="{'background-color':'green'}"></<div>

判断添加

<div [ngStyle]="{'background-color':username === 'zxc' ? 'green' : 'red' }"></<div>

2、ngClass 

第一个参数为类名称,第二个参数为boolean值,如果为true就添加第一个参数的类

基本用法

[ngClass]="{'text-success':true}"

判断

[ngClass]="{'text-success':username == 'zxc'}"

[ngClass]="{'text-success':index == 0}"

3、例子循环显示的第一行添加text-danger样式,文字变红色

const arr = [1, 3, 4, 5, 6]

<ul>

<li *ngFor="let item of arr, let i = index">

<span [ngClass]="{'text-danger': i==0}">{{item}}</span>

</li>

</ul>

 

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值