百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>JS教程> 分享Angular中关于表单的一些知识点
分享文章到:

分享Angular中关于表单的一些知识点

发布时间:12/01 来源:未知 浏览: 关键词:
本篇文章给大家分享一些Angular表单相关的知识点。有必然的参照 价值,有需要的伴侣可以参照 一下,但愿对大家有所帮忙。

相关教程引荐:《angularjs视频教程》

点击输入框,全选内容

<input type="text" name="time" onfocus="this.select();" />

点击输入框,清空内容

<input type="text" name="time" onclick="this.value=''" /></td>

通过事件猎取输入框的值

(<HTMLInputElement>event.target).value

value与ngValue

[value]="..." 仅支撑字符串值
[ngValue]="..." 支撑任何类型

常用的正则表达式

取值范畴20-360:^(([2-9][0-9])|([1-2][0-9][0-9])|([3][0-5][0-9]))$|^[3][6][0]$
整数:^-?d+$
浮点数:^(-?d+)(.d+)?$
正浮点数:^(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*))$
负浮点数 ^(-(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*)))$
非负浮点数(正浮点数 + 0):^d+(.d+)?$
非正浮点数(负浮点数 + 0) ^((-d+(.d+)?)|(0+(.0+)?))$

关于ngForm

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

@Component({
  selector: 'example-app',
  template: `
    <form #f="ngForm" (ngSubmit)="onSubmit(f)" novalidate>
      <input name="first" ngModel required #first="ngModel">
      <input name="last" ngModel>
      <button>Submit</button>
    </form>

    <p>First name value: {{ first.value }}</p>
    <p>First name valid: {{ first.valid }}</p>
    <p>Form value: {{ f.value | json }}</p>
    <p>Form valid: {{ f.valid }}</p>
  `,
})
export class SimpleFormComp {
  onSubmit(f: NgForm) {
    console.log(f.value);  // { first: '', last: '' }
    console.log(f.valid);  // false
  }
}

1.png

  • #first="ngModel" 把 NgModel 输出成了一个名叫 first 的部分变量。NgModel 把本人操纵的 FormControl 实例的属性映射出去,让你能在模板中检查控件的状态,比方 valid 和 dirty
  • 使用带有ngModel<input>标签时,系统会主动为这个标签创立一个叫做FormControl的对象,并且会主动把它增加到FormGroup中。而FormControlFomGroup中是用<input>标签上的name属性来做标识的,所以必需增加name属性。

HTML5中新的input类型

import { Component, OnInit } from '@angular/core';
import {Data} from "popper.js";
@Component({
  selector: 'app-test-data',
 template: `
 <p> test-data works! </p> <input type="date" [(ngModel)]="date">{{date}}<br>
 <input type="month" [(ngModel)]="month">{{month}}<br>
 <input type="week" [(ngModel)]="week">{{week}}<br>
 <input type="time" [(ngModel)]="time">{{time}}<br>
 <input type="datetime-local" [(ngModel)]="datetimeLocal">{{datetimeLocal}}
 <input id="myCar" list="cars" /> 
 <datalist id="cars"> 
    <option value="BMW"> 
    <option value="Ford"> 
    <option value="Volvo"> 
 </datalist> `,
 styles: [
  ]
})
export class TestDataComponent implements OnInit {
 date:string;
 month:string;
 week:string;
 time:string;
 datetimeLocal:string;
 constructor() { }
  ngOnInit(): void {
  }
}

keyup事件和input事件的不同

前端停止反复性校验,若使用keyup事件停止推断时,输入已有的数据同时点击鼠标,反复性校验会失效。

ngif的小问题

  • ngif操纵可否显现的input内容,没方法用#绑定来验证有效性,但可以用hidden实现类似功效

501

假如后端没有给前端返回值,前端会报501错误

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板