tip:

数据的双向绑定(数据的双向绑定只是针对表单)
实现数据的双向绑定需要在app_module.ts(根模块)中进行注册一些东西
import {FormsModule} from '@angular/forms';
@NgModule中的imports中进行声明一下FormsModule
 
html:
  

  <div class="form">
    <p>人员登录系统</p>
    <ul>
      <li>姓名:<input type="text" [(ngModel)]="peopleInfo.username"></li>
      <li>写别:<input type="radio" name="sex" value="1" [(ngModel)]="peopleInfo.sex"><label [for]="sex1">男</label>
            <input type="radio" name="sex" value="2" [(ngModel)]="peopleInfo.sex"><label [for]="sex2">女</label>
      </li>
      <li>
        城市:<select [(ngModel)]="peopleInfo.city">
            <option *ngFor="let item of peopleInfo.citylist" [value]="item">{{item}}</option>
          </select>
      </li>
      <li>爱好:<span *ngFor="let item of peopleInfo.hobby;let key=index">          
            <input type="checkbox" [id]="'checked'+key" [(ngModel)]="item.checked">
            <label [for]="'checked'+key">{{item.title}}</label>
          </span>
      </li>
      <li>描述:<textarea [(ngModel)]="peopleInfo.mark">{{mark}}</textarea></li>
      <li><button (click)="dosubmit();" class="submit">提交</button></li>
    </ul>
  </div>
 
ts中:
  

  public peopleInfo:any={
    username:"",
    sex:"1",
    city:"北京",
    citylist:["北京","上海","深圳"],
    hobby:[
      {title:"吃饭",checked:true},
      {title:"睡觉",checked:false},
      {title:"打豆豆",checked:false}],
    mark:""
    };
 
dosubmit(){
console.log(this.peopleInfo);
}

select 难点详解:
    [(ngmodle)]是双向绑定的写法,propleInfo.sex在ts中的值为1,默认为男,
    (判断peopleInfo。sex是否为1,是则为选中,判断的依据是peopleInfo.sex的值是否和当前的value的值相等,相等则为选中,反之未选中),
    当点击为女的时候,将女的值传递给sex
 
    select中:*ngFor="let item of peopleInfo.citylist" 循环获取到对象中的城市列表中的值,{{item}}是为循环出来的值,
    [value]="item"是为:value属性的值为item ,此时的value的值是和循环出来的值为相同。
    [(ngModel)]="peopleInfo.city" 绑定city是因为城市选项中绑定的一些值都是在select的时候有一个值,故此要给select标签进行一次绑定数据,
    当发现peopleInfo.city的值和option中的哪一个[value]="item"相等时。如果相等就选中那个option,同理,当option改变的时候,也会重新在赋值
    给peopleInfo.city。同时,当我们在option选择一个值的时候也是最终显示在select的标签之中,所以在此select进行数据绑定也就行得通了,在页面中看不到的可以通过
    console.log来查看
 
checkbox 难点详解
    *ngFor="let item of peopleInfo.hobby;let key=index"循环peopleInfo对象下的hobby中的值,key=index是为索引,[id]和[for]的值是一样的是为了进行对应
    所以写成:[for]="'checked'+key",[id]="'checked'+key"都是为了拿到chedked值,[(ngModel)]="item.checked"是为了检测是否选中,在爱好选项中只有第一个值为true,
    其他为false,但是只要点中一个就要进行改变其checked的值,所以这是时候就会把itemed.checked的值赋值给ts中的checked,从而实现双向绑定。

ng form组件(表单)的更多相关文章

  1. 解析:使用easyui的form提交表单,在IE下出现类似附件下载时提示是否保存的现象

    之前开发时遇到的一个问题,使用easyui的form提交表单,在Chrome下时没问题的,但是在IE下出现类似附件下载时提示是否保存的现象. 这里记录一下如何解决的.其实这个现象不光是easyui的f ...

  2. 阻止form空表单提交----JavaScript

    网上看到很不错的阻止form空表单提交 第一种方法 <div class="warp"> <h2>登录到pfan空间</h2> <p> ...

  3. form注册表单圆角 demo

    form注册表单圆角 <BODY> <div class="form"> <ul class="list"> <li& ...

  4. Form提交表单页面不跳转

    1.设计源码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

  5. 使用easyui的form提交表单,在IE下出现类似附件下载时提示是否保存的现象

    之前开发时遇到的一个问题,使用easyui的form提交表单,在Chrome下时没问题的,但是在IE下出现类似附件下载时提示是否保存的现象. 这里记录一下如何解决的.其实这个现象不光是easyui的f ...

  6. WP Mail SMTP插件解决Contact Form 7表单提交失败问题

    WP Mail SMTP插件解决Contact Form 7表单提交失败问题 WP Mail SMTP是一款非常优秀的解决WordPress主机因为不支持或者是禁用了mail()函数,导致无法实现在线 ...

  7. elementui 多组件表单验证

      最近在做管理后台,vue2.0基于elementui框架进行开发. elementui的api中表单验证都是单个vue文件的验证.而我的保存按钮放在了父组件了,验证对象为三个子组件我的灵机一动 想 ...

  8. 关于form与表单提交操作的一切

    原文链接:http://caibaojian.com/form.html 你知道,一个表单里面只要有form元素,如果没有给action加一个默认值,为空白的时候,当你刷新页面时,会弹出一个警告框提示 ...

  9. 【转】document.form.action,表单分向提交

    document.form.action,表单分向提交,javascript提交表单 同一个表单可以根据用户的选择,提交给不同的后台处理程序.即,表单的分向提交.如,在编写论坛程序时,如果我们希望实现 ...

  10. 【开发】Form Validate 表单验证 扩展应用

    目录: ★.文本输入框(easyui-textbox) ★.数字框(easyui-numberbox) ★.时间(easyui-datebox) ★.文本域(easyui-textbox easyui ...

随机推荐

  1. [python]python子字符串的提取、字符串连接、字符串重复

    1. python使用索引运算符[]和切片运算符[:],来提取字符串. 第一个字符的索引是0,最有一个字符的索引是-1,切片运算符[x:y]表示提取从索引x到索引y-1的字符,不包含索引y. 示例: ...

  2. P3980 [NOI2008]志愿者招募 费用流 (人有多大胆地有多大产

    https://www.luogu.org/problemnew/show/P3980 感觉费用流比网络流的图更难想到,要更大胆.首先由于日期是连续的,所以图中的点是横向排列的. 这道题有点绕道走的意 ...

  3. P1640 [SCOI2010]连续攻击游戏 二分图构造

    https://www.luogu.org/problemnew/show/P1640 题意 lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10 ...

  4. CodeForces 669 E Little Artem and Time Machine CDQ分治

    题目传送门 题意:现在有3种操作, 1 t x 在t秒往multiset里面插入一个x 2 t x 在t秒从multiset里面删除一个x 3 t x 在t秒查询multiset里面有多少x 事情是按 ...

  5. Windows CVE-2019-0708 远程桌面代码执行漏洞复现

    Windows CVE-2019-0708 远程桌面代码执行漏洞复现 一.漏洞说明 2019年5月15日微软发布安全补丁修复了CVE编号为CVE-2019-0708的Windows远程桌面服务(RDP ...

  6. Intel X86 32位CPU内存管理----《Linux内核源码情景分析》笔记(一)

    Intel X86 32位CPU内存管理 在X86系列中,8086和8088是16为处理器,而从80386开始为32为处理器,80286则是该系列从8088到80386,也就是16位处理器到32位处理 ...

  7. Seaborn数据可视化入门

    在本节学习中,我们使用Seaborn作为数据可视化的入门工具 Seaborn的官方网址如下:http://seaborn.pydata.org 一:definition Seaborn is a Py ...

  8. ReentrantReadWriteLock总结

    ReentrantReadWriteLock的流程的一些特性: // ReentrantReadWriteLock.WriteLock.lock()特性: • 已持有读锁的线程不能再持有写锁: • 已 ...

  9. CXF添加拦截器和自定义拦截器

    前面讲了如何采用CXF开发webservice,现在来讲如何添加拦截器和自定义拦截器. 服务端代码: HelloWorld implementor=new HelloWorldImpl(); Stri ...

  10. Git学习-上传项目到github

    现在流行把项目代码上传到git上,今天试了好久,终于成功上传到git了,特做点笔记. 准备工作 在github上注册一个账号,创建一个仓库. 创建好仓库,得到它的地址: 开始上传 一.新建一个文件夹, ...