Angular用户输入
用户输入
事件绑定
使用
- (event)
- on-event
概念
用户操作 -> DOM事件
- 用户操作
- 点击链接
- 按下按钮
- 输入文字
- DOM事件
- $event
- 类型
- any
- 不能推测属性
- 可能导致错误
- 指定类型
- 组件需要了解过多的模板细节
- 违反了分离关注原则
- any
- 标准的HTML DOM事件
- 有target属性
- 类型
- $event
示例
模板
<button (click)="OnClickMe()">non $event</button>
<!--
$event传参
keyup -> 键盘按下并松开 事件
-->
<input on-keyup="onKey($event)" />
组件
inputContent = '';
inputKey = '';
onKey(event: any): void {
this.inputContent += event.target.value + '|';
this.inputKey += event.key + '|';
}
// 指定事件类型
onKey(event: KeyboardEvent): void {
// $event.target -> HTML元素
// 转换元素类型 -> 不是每个元素都有value
// HTMLInputElement.value -> 当前输入框的内容
this.inputContent += (event.target as HTMLInputElement).value + '|';
// key -> 按下的键
this.inputKey += event.key + '|';
}
模板变量
使用方式
name
- ref-name
实例
模板
<!--
响应了异步事件(按键)-> 触发绑定更新机制 -> 视图刷新
极简写法 (keyup) = "0"
-->
<input #inputElement (keyup)="0"/>
<p>{{inputElement.value}}</p>
<!--
优点:
无需了解$event及其结构
组件从模板获取的是干净的信息
-->
<input ref-input (keyup)="onKey(input.value)" />
<p></p>
组件
inputContent = '';
onKey(value: string): void {
this.inputContent += value + '|';
}
事件筛选
事件处理器 event-handler
模板
<input (keyup)="onKey($event)" />
{{inputContent}}
组件
inputContent = '';
onKey(event: KeyboardEvent): void {
if (event.key === 'Enter'){
this.inputContent += (event.target as HTMLInputElement).value + '|';
}
}
伪事件 pseudo-event
不存在DOM事件,属于angular的语法糖
模板
<input #input (keyup.enter)="onKey(input.value)" />
{{inputContent}}
组件
inputContent = '';
onKey(value: string): void {
this.inputContent += value + '|';
}
失焦事件 blur-event
鼠标聚焦到其他位置时,引发的操作
模板
<input #input (keyup.enter)="onKey(input.value)" (blur)="onKey(input.value)" />
{{inputContent}}
组件
inputContent = '';
onKey(value: string): void {
this.inputContent += value + '|';
}
总结
适用于小规模的输入,如果大型输入使用双向绑定-NgModel更简单优雅。
Angular用户输入的更多相关文章
- Angular2 表单(一) 用户输入
绑定到用户输入事件 等号左边的 (click) 表示把按钮的点击事件作为绑定目标. 等号右边引号中的文本是模板语句,通过调用组件的 onClickMe 方法来响应这个点击事件. <button ...
- 防御XSS攻击-encode用户输入内容的重要性
一.开场先科普下XSS 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS.恶 ...
- python学习笔记(基础二:注释、用户输入、格式化输出)
注释 单行:# 多行:上下各用3个连续单引号或双引号 3个引号除了多行注释,还可以打印多行 举例: msg = ''' name = "Alex Li" name2 = name ...
- 第4章 Java接收用户输入
第4章 Java接收用户输入 1.输入 使用Scanner工具类可以换取用户输入的数据Scanner类位于java.util包中,使用时需要导入此包使用步骤: 1.导入java.util.Scanne ...
- Python学习【第四篇】用户输入及判断
用户输入: 例1.写一个用户输入密码的小程序,流程如下: 1.用户输入自己的用户名 2.打印"Hello+用户名" #!/usr/bin/env python #name = ra ...
- 使用scanner工具类来获取用户输入的信息
使用scanner工具类来获取用户输入的成绩信息. 步骤:1.导入java.util.Scanner包 2.创建Scanner对象 3.接受并保存用户输入的值 例子:通过用户输入来获取学生成绩 pac ...
- alertDialog创建登陆界面,判断用户输入
alertDialog创建登陆界面,需要获取用户输入的用户名和密码,获取控件对象的时候不能像主布局文件那样获得, 需要在onClickListener中获取,代码如下: public boolean ...
- Asp.Mvc中的text实现 辅助用户输入 灰色字体
在开发Web应用程序中经常需要用户在文本框输入信息,为了提高程序人性化设置以及用户体验效果常常需要在文本框中显示灰色字体辅助用户输入 如:
- python学习道路(day1note)(变量,注释,用户输入,格式化输出,if,while,for循环并扩展练习)
python是一门动态解释性的强类型定义语言,其应用范围非常之广 1:进入python语言 #!/usr/bin/env python #_*_coding:utf-8_*_ print(" ...
随机推荐
- unity探索者之微信分享回调
版权声明:本文为原创文章,转载请声明http://www.cnblogs.com/unityExplorer/p/7574561.html 上一遍讲了微信分享的一些坑,然后就忘了回调这事儿了,今天补上 ...
- JS 时间获取 (常用)
/** * 获取几天之前日期 */ daysAgo(dayNum = 0) { let myDate = new Date() let lw = new Date(myDate - 1000 * 60 ...
- java如何将char类型的数字转换成int型的数字,而不是Ascii
如何把 char ‘3’ 转为 int 3, 大家应该知道,不能直接转化,那样得到是‘3’的Ascii. 如下面: public class Leet { public static void mai ...
- python格式化输出及大量案例
python格式化输出符号及大量案例 1.格式化输出符号 python格式化输出符号 格式化符号 含义 %c 转化成字符 %r 优先使用repr()函数进行字符串转化 %s 转换成字符串,优先使用st ...
- 玩转Spring——Spring IOC/DI
什么是IOCioc :Inversion of Control,即控制反转. 它不是一种技术,而是一种设计思想,即java程序中获取对象的方式发生反转,由最初的new方式创建,转变成由第三方框架创建. ...
- neighbor和neigh_modify(转载)
(转载:http://blog.sina.com.cn/s/blog_b48a7ac30102w4mg.html###) 以下取自:http://simulation.haotui.com/viewt ...
- 区块链入门到实战(23)之以太坊(Ethereum) – 虚拟机架构
以太坊(Ethereum)网络中,定义了一组通用协议用于支持智能合约的运行,其核心便是以太坊(Ethereum)虚拟机. 下图解释了该架构: 开发人员使用Solidity等开发语言开发智能合约 源程序 ...
- MPI实现Jacobi
一.Jacobi迭代 #include<stdio.h> #include<mpi.h> #include<stdlib.h> #define totalsize ...
- day03 每日一行
day03 每日一行 问题描述 用列表解释式 .生成器表达式实现 字典列表为: [{'first': 'john', 'last': 'smith', 'email': 'jsmith@exsampl ...
- 面经手册 · 第8篇《LinkedList插入速度比ArrayList快?你确定吗?》
作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 你以为考你个数据结构是要造火箭? 汽车75马力就够奔跑了,那你怎么还想要2.0涡轮+ ...