ng2 学习笔记(一)

ng2发布了一段时间,最近才开始着手学习一下,ng2可以说变化海是比较大的,现在写一些学习过程中要注意的点,新手可以参考,大神可以指导:

按照文档来吧:

1、快速开始:没什么可说的,直接上git 克隆官方的quick-start,

git clone https://github.com/angular/quickstart.git quickstart
cd quickstart
npm install
npm start

2、官方的第一个例子:

ngFor循环列表,ng2要定义一个局部变量,还要注意前面的*号:<li *ngFor="let list of listArr">{{list}}</li>;注意下格式就ok了;

3、用户输入:

这个例子个人觉得用到的场景不会太多;

主要是是涉及到input框的的事件绑定以及value的获取方式:

  1)、直接绑定事件:(keyup)="keyUpEvent($event)";这里传入了一个$event事件,由于$event是一整个DOM元素事件及属性,所以效率比较低;

  2)、angularjs的模版引用变量直接访问input的值;<input (keyup)="uinput2(box2.value)" #box2/>;效率比较高推荐使用;

  3)、当input要绑定处理事件的时候,可以1)、2)方法合用。<input type="text" (keyup.enter)="addList(list.value)" #list/>

4、表单:这个用处比较大,主要用到的是数据的双向数据绑定[(ngModel)]="args";

这里有一个坑,就是要完成表单的双向数据绑定需要加载一个angular模块FormsModule,这个模块要在app.module的主模块里引用,并且在@NgModule的imports里加入。这样才能正常工作,不然双向数据绑定不上。应该是双向数据绑定都要引入FormsModule这个模块;至于表单验证在下一次总结在写;

 

【其他的坑】:

1、定义一个组件时,要引用时都需要在app.module的主模块了进行引入;并且在@NgModule的declarations里声明;

2、ngnice.cn这个angular中文网上的文档,比较坑,基础的绑定等操作在后面,实例在前面,这样容易对新手造成困惑;

 

下面贴一下代码:

app.module.ts文件:

import { NgModule }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';

import { FormsModule } from '@angular/forms';
import { AppComponent }  from './app.component';
import { ClickMeComponent } from './click-me.component';
import { UserForm } from './form.component';

@NgModule({
  imports:      [ BrowserModule ,FormsModule],
  declarations: [ AppComponent , ClickMeComponent,UserForm,],
  bootstrap:    [ AppComponent ]
})

export class AppModule { }

 

用户输入组件的代码:

import { Component } from '@angular/core';

@Component({
    selector:'user-input',
    template:`
        <h2>用户输入:</h2><hr />
        <h4>绑定keyUp事件获取用户输入事件</h4>
        <input (keyup)="uinput($event)" />
        <p>您输入的信息是:{{msg}}</p>
        <br />
        <h4>使用 Angular 的模板引用变量</h4>
        <input (keyup)="0" #box/><b>(已输入{{box.value.length}}个字,还可以输入:{{10-box.value.length}}个字)</b>
        <p>您输入的信息是:{{box.value}}</p>
        <br />
        <h4>组合使用效率更高</h4>
        <input (keyup)="uinput2(box2.value)" #box2/>
        <b *ngIf="box2.value.length<=10">(已输入{{box2.value.length}}个字,还可以输入:{{10-box2.value.length}}个字)</b>
        <b *ngIf="box2.value.length>10">(超过输入:{{box2.value.length-10}}个字)</b>
        <p>您输入的信息是:{{msg2}}</p>
        <br />
        <h3>实例:</h3>
        <div>
            <input type="text" (keyup.enter)="addList(list.value)" #list/>
            <button (click)="addList(list.value)">添加到列表</button>
            <ul>
                <li *ngFor="let list of likeList">{{list.call}}</li>
            </ul>
        </div>
    `
})

export class ClickMeComponent {
    msg = '未输入';
    uinput(evt){
        // 传递整个dom以及事件,性能差
        console.log(evt);
        this.msg = evt.target.value ? evt.target.value : '未输入';
    }

    msg2 = '未输入';
    uinput2(val:string){
        if(val.length>10){
            this.msg2 = val.substring(0,10) ? val.substring(0,10) : '2未输入';
        }else{
            this.msg2 = val ? val : '2未输入';
        }
    }

    likeList = [
        {"id":1000,"call":"读书"}
    ];
    addList(val){
        var id = +new Date();
        this.likeList.push({"id":id,"call":val});
    }
}

 

FORM表单的数据绑定:

import { Component } from '@angular/core';
import { Hero } from './hero';

@Component({
    selector:'hero-form',
    template:`
        <h2>FORM 表单</h2>
        <hr />
        <div class="container">
            <h4>Hero Form</h4>
            <form>
                <div class="form-group">
                    <label for="name">Name</label>
                    <input type="text" class="form-control" name="name" [(ngModel)]="model.name" id="name" required>
                </div>
                <div class="form-group">
                    <label for="power">Hero Power</label>
                    <select class="form-control" id="power" [(ngModel)]="model.power" required name="power">
                        <option *ngFor="let pow of powers" [value]="pow">{{pow}}</option>
                    </select>
                </div>
                <div class="form-group">
                    <label for="alterEgo">Alter Ego</label>
                    <input type="text" class="form-control" [(ngModel)]="model.alterEgo" name="alterEgo" id="alterEgo">
                </div>
                <button type="button" (click)="submit()" class="btn btn-default">Submit</button>
            </form>
        </div>
    `
})

export class UserForm {
    powers = ['Really Smart', 'Super Flexible',
            'Super Hot', 'Weather Changer'];
      model = new Hero(18, 'Dr IQ', this.powers[0], 'Chuck Overstreet');
      submitted = false;
      //onSubmit() { this.submitted = true; }
      submit(){
          console.log(this.model)
      }
}

 

 

以上内容欢迎各位大神批评指导!

posted @ 2017-02-21 20:30  一步小僧  阅读(1141)  评论(0编辑  收藏  举报
一步小僧哈哈