Angular基础---HelloWorld---Day3

news2024/9/28 19:27:52

文章目录

      • 0.ng-model 的几种不同的class属性
      • 1.ng-model 的引用与属性的调用
      • 2.表单验证: (模版引用变量、ngModel 、ngif一起使用)
      • 3.根据class属性的值ng-invalid ,设置动态变化的样式


0.ng-model 的几种不同的class属性

引用ng-model 元素的class属性,有一些值是自动变化的,来反映ng-model的不同状态。class的值大致有如下:

idattributeremark
1ng-empty
2ng-not-empty不空
3ng-touched和控件进行过交互
4ng-untouched和控件没有进行过交互
5ng-valid表单通过验证
6ng-invalid表单未通过验证
7ng-valid-[key]:由$setValidity添加的所有验证通过的值
8ng-invalid-[key]:由$setValidity添加的所有验证失败的值
9ng-dirtytrue表示有修改表单
10ng-pending任何为满足$asyncValidators的情况
11ng-pristine控件为初始状态
# required 代表此输入框是必须有内容的
# [(ngModel)]="inputContent" 代表引入的ngModel数据,最终输出给inputContent这个变量

<input required type="input box" [(ngModel)]="inputContent" [id]="'ng-model-attribute'">

在这里插入图片描述



1.ng-model 的引用与属性的调用


在ts文件中先声明变量,值的内容为空:
在这里插入图片描述


<hr>
<!-- ngModel 的引用和属性调用 -->
<form action="" [id]="'ng-model-cite'">
    <!-- 此处声明模版引用变量#nameInp,设置noModel的value值为fromData.name,  #nameInp="ngModel"代表将本元素的ngModel对象赋值给模版引用变量 -->
    账号:<input required #nameInp="ngModel" type="text" [(ngModel)]="fromData.name" name="userName123">
    <br>
    <!-- nameInp.valid 直接调用ngModel的属性valie 是否为true -->
    元素是否有效:<span>{{nameInp.valid}}</span>
    <br>
    ngModel的name: <span>{{nameInp.name}}</span>
    <br>
    ngModel的值: <span>{{nameInp.value}}</span>
    <br>
    <br>
    密码:<input required #pasInp="ngModel" type="text" [(ngModel)]="fromData.password" name="password123">
    <br>
    元素是否有效:<span>{{pasInp.valid}}</span>
    <br>
    ngModel的name: <span>{{pasInp.name}}</span>
    <br>
    ngModel的值: <span>{{pasInp.value}}</span>
</form>


页面刷新看到的效果如下:
在这里插入图片描述


输入内容之后看到的效果如下:

在这里插入图片描述



2.表单验证: (模版引用变量、ngModel 、ngif一起使用)


<!-- 表单验证功能 -->
<form action="" [id]="'verify-form'">
    账号:<input required #nameInput="ngModel" type="text" [(ngModel)]="fromData.name" name="userName">
    <br>
    <!-- 当ngModel所在元素input为invalid的时候,span渲染,出现提示框 -->
    <span *ngIf="!nameInput.valid">请输入账号</span>
    <br>
    密码:<input required #pasInput="ngModel" type="text" [(ngModel)]="fromData.password" name="password">
    <br>
    <span *ngIf="!pasInput.valid">请输入密码</span>
    <br>
    <!-- 输出fromData数据信息 -->
    <button (click)="subBtnFun(fromData)">提交信息</button>
</form>


刷新之后看到的效果:
在这里插入图片描述


输入内容之后看到的效果:
在这里插入图片描述


点击提交按钮看到的效果:
在这里插入图片描述



3.根据class属性的值ng-invalid ,设置动态变化的样式

在这里插入图片描述

在这里插入图片描述

项目代码地址:
https://gitee.com/super-alien/angularStudy

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1506679.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++:类和对象(三)——拷贝构造函数和运算符重载

目录 一、拷贝构造函数 1.概念 2.特性 二、赋值运算符重载 1.运算符重载 2.赋值运算符重载 &#xff08;1&#xff09;注意的点&#xff1a; &#xff08;2&#xff09;赋值运算符不允许被重载为全局函数&#xff0c;只能重载为类的成员函数 &#xff08;3&#xff09;…

YOLO语义分割标注文件txt还原到图像中

最近做图像分割任务过程中&#xff0c;使用labelme对图像进行标注&#xff0c;得到的数据文件是json&#xff0c;转换为YOLO训练所需的txt格式后&#xff0c;想对标注文件进行检验&#xff0c;即将txt标注文件还原到原图像中&#xff0c;下面是代码&#xff1a; import cv2 im…

工资低适合下班做的6大副业,每一个都值得尝试!

2024年是最适合发展个人副业的时候&#xff01;无论你是否有全职工作&#xff0c;如果你的主业还不能满足你的成就感&#xff0c;还不能满足你的生活需求&#xff0c;这6个下班可以做的副业都很值得尝试&#xff01; 千金宝库做简单的网络任务 近年来&#xff0c;随着互联网技…

【异常 - 错误的更优解决方案】

目录&#xff1a; 前言异常&#xff08;一&#xff09; c语言原有的错误处理方式&#xff08;二&#xff09; 异常的概念&#xff08;三&#xff09;异常的使用1.异常的抛出与捕捉2.函数调用链中异常栈的展开原则 &#xff08;四&#xff09;5组测试及对应结论1.常规测试2.异常…

牛客周赛 Round 36

赛况 C题可惜&#xff0c;比赛时模拟没有想明白&#xff0c;只对了一半&#xff0c;赛后看了大佬们的题解后恍然大悟&#xff0c;而F题是压根没思路&#xff0c;况且F题部分分也比较难拿。 题目列表 A-小红的数位删除 思路 将读入的数字整除10做三次后输出即可 参考代码 #inc…

车载诊断协议DoIP系列 —— AL IPv6地址分配通用DoIP报头结构

车载诊断协议DoIP系列 —— AL IPv6地址分配&通用DoIP报头结构 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师(Wechat:gongkenan2013)。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 本就是小人物,输了就是输了,不要在意别人怎么看自…

️ IP代理实操指南:如何在爬虫项目中避免封禁和限制 ️‍♂️

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

动静态库

inode inode用于管理文件属性和内容 一个文件只能有一个inode&#xff0c;一个inode可以对应多个文件名 Linux进程中&#xff0c;打开的每一个文件都有对应的文件inode属性和文件页缓冲区&#xff08;内存和磁盘的缓冲区&#xff09; 软硬链接 硬链接 多个文件指向同一个i…

2024年软件测试怎么自我提升?“我“该如何做?

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、掌握基本的测试…

【Python】实战教学:给定二维numpy数组,将其转为csv格式并保存(指定列名)

【Python】实战教学&#xff1a;给定二维numpy数组&#xff0c;将其转为csv格式并保存&#xff08;指定列名&#xff09; &#x1f308; 个人主页&#xff1a;高斯小哥 &#x1f525; 高质量专栏&#xff1a;Matplotlib之旅&#xff1a;零基础精通数据可视化、Python基础【高质…

利用YOLOv5模型进行锥桶识别

目录 1. YOLOv5模型简介 2. 准备数据集 3. 训练模型 4. 模型评估 5. 模型部署与应用 6. 注意事项 在计算机视觉领域&#xff0c;目标检测是一项重要的任务&#xff0c;它可以帮助我们识别图像或视频中的特定物体并进行定位。而YOLOv5是一种高效的目标检测模型&#xff0c…

某app zzReqSign 算法还原分析过程

文章目录 前言一、抓包确定目标二、反编译定位加密位置三、反编译定位加密位置四、frida hook验证五、进一步分析so六、算法还原结束语------------------------------------------------END-------------------------------------------- 前言 工欲善其事必先利其器 准备工具…

Java“树结构TreeNode”用法详解,二叉树用法实现代码!!!

一、TreeNode用法 在Java中&#xff0c;TreeNode通常用于表示树结构中的节点。在树结构中&#xff0c;每个节点可以有零个或多个子节点&#xff0c;而TreeNode就是这个树结构中的一个节点。通常&#xff0c;树结构是通过链式结构实现的&#xff0c;每个节点有指向其子节点的引…

ubuntu20.04环境搭建:etcd+patroni+pgbouncer+haproxy+keepalived的postgresql集群方案

搭建基于etcdpatronipgbouncerhaproxykeepalived的postgresql集群方案 宿主机操作系统:ubuntu20.04 使用kvm搭建虚拟环境(如没有安装kvm&#xff0c;请先自行安装kvm) 1、安装kvm服务 ①、查看虚拟支持 如果CPU 支持硬件虚拟化则输出结果大于0&#xff0c;安装kvm-ok命令检…

(黑马出品_06)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式

&#xff08;黑马出品_06&#xff09;SpringCloudRabbitMQDockerRedis搜索分布式 微服务技术ES搜索和数据分析 今日目标1. 查询文档1.1.DSL查询分类1.2.全文检索查询1.2.1.使用场景1.2.2.基本语法1.2.3.示例 1.3.精准查询1.3.1.term查询1.3.2.ran…

CSP初赛备考—汉字与运算

汉字 英文字符 英文字符的编码有两种&#xff1a;①ASCII标准码&#xff0c;7位&#xff08;128个字符&#xff09;②ASCII扩展吗&#xff0c;8位&#xff08;256个字符&#xff09; 中文字符 汉字分为两级&#xff1a;①一级汉字&#xff1a;3755个&#xff0c;按汉语拼音字…

STM32CubeIDE基础学习-STM32CubeIDE软件程序下载方法

STM32CubeIDE基础学习-STM32CubeIDE软件代码下载方法 文章目录 STM32CubeIDE基础学习-STM32CubeIDE软件代码下载方法前言第1章 代码下载第2章 下载器固件更新总结 前言 编写完代码&#xff0c;一般都会选择在线下载程序的方式进行验证该程序是否正确&#xff0c;如果发现结果和…

不会用虚拟机装win10?超详细教程解决你安装中的所有问题!

前言&#xff1a;安装中有任何疑问&#xff0c;可以在评论区提问&#xff0c;博主身经百战会快速解答小伙伴们的疑问 BT、迅雷下载win10镜像&#xff08;首先要下载win10的镜像&#xff09;&#xff1a;ed2k://|file|cn_windows_10_business_editions_version_1903_updated_sep…

恋活2 仿原神人物卡系列2全合集打包

内含&#xff1a;炽沙话事人 芭别尔迪希雅镀金女团 -沙中净水镀金女团 -叶轮舞者珐露珊坎蒂丝柯莱可莉丽莎-叶隐芳名神里绫华-花时来信瑶瑶。 下载地址&#xff1a; https://www.changyouzuhao.cn/13661.html

HarBor私有镜像仓库安装部署

环境准备 #>>> redis $ yum -y install redis $ systemctl enable --now redis $ vim /etc/redis.conf modify: bind <ipaddress> $ systemctl restart redis#>>> nfs $ yum -y install nfs-utils $ mkdir -p /data/harbor $ vi /etc/exports /data/h…