用户输入

事件绑定

使用

  • (event)
  • on-event

概念

​ 用户操作 -> DOM事件

  • 用户操作

    • 点击链接
    • 按下按钮
    • 输入文字
  • DOM事件
    • $event

      • 类型

        • any

          • 不能推测属性
          • 可能导致错误
        • 指定类型
          • 组件需要了解过多的模板细节
          • 违反了分离关注原则
      • 标准的HTML DOM事件
        • 有target属性

示例

模板
<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用户输入的更多相关文章

  1. Angular2 表单(一) 用户输入

    绑定到用户输入事件 等号左边的 (click) 表示把按钮的点击事件作为绑定目标. 等号右边引号中的文本是模板语句,通过调用组件的 onClickMe 方法来响应这个点击事件. <button ...

  2. 防御XSS攻击-encode用户输入内容的重要性

    一.开场先科普下XSS 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS.恶 ...

  3. python学习笔记(基础二:注释、用户输入、格式化输出)

    注释 单行:# 多行:上下各用3个连续单引号或双引号 3个引号除了多行注释,还可以打印多行 举例: msg = ''' name = "Alex Li" name2 = name ...

  4. 第4章 Java接收用户输入

    第4章 Java接收用户输入 1.输入 使用Scanner工具类可以换取用户输入的数据Scanner类位于java.util包中,使用时需要导入此包使用步骤: 1.导入java.util.Scanne ...

  5. Python学习【第四篇】用户输入及判断

    用户输入: 例1.写一个用户输入密码的小程序,流程如下: 1.用户输入自己的用户名 2.打印"Hello+用户名" #!/usr/bin/env python #name = ra ...

  6. 使用scanner工具类来获取用户输入的信息

    使用scanner工具类来获取用户输入的成绩信息. 步骤:1.导入java.util.Scanner包 2.创建Scanner对象 3.接受并保存用户输入的值 例子:通过用户输入来获取学生成绩 pac ...

  7. alertDialog创建登陆界面,判断用户输入

    alertDialog创建登陆界面,需要获取用户输入的用户名和密码,获取控件对象的时候不能像主布局文件那样获得, 需要在onClickListener中获取,代码如下: public boolean ...

  8. Asp.Mvc中的text实现 辅助用户输入 灰色字体

    在开发Web应用程序中经常需要用户在文本框输入信息,为了提高程序人性化设置以及用户体验效果常常需要在文本框中显示灰色字体辅助用户输入 如:

  9. python学习道路(day1note)(变量,注释,用户输入,格式化输出,if,while,for循环并扩展练习)

    python是一门动态解释性的强类型定义语言,其应用范围非常之广 1:进入python语言 #!/usr/bin/env python #_*_coding:utf-8_*_ print(" ...

随机推荐

  1. 7. oracle表的管理*

    一.表名和列名的命名规则: 1.必须以字母开头 2.长度不能超过30个字符 3.不能使用oracle的保留字 4.只能使用如下字符 A-Z,a-z,0-9,$,#等 二.Oracle数据类型1.字符类 ...

  2. magento2 pub/static没有adminhtml,frontend的解决方案

    (1) 运行php bin/magento setup:static-content:deploy (2) 检查pub/static有没有.htaccess文件 (3) php bin/magento ...

  3. circos pipeline

    # /usr/bin/env python# coding=utf-8#################################### Author : yunkeli# Version : ...

  4. Manico--自定义应用快速切换

    快速切换应用的app,使用非常频繁,奈何还是没有钱! 这玩意儿虽然免费,但是时不时跳一个弹框让你购买,也是够烦的,然后我们正好利用逆向工具,对着玩意儿进行破解,让它不再弹框! 下载安装Hopper D ...

  5. java23种设计模式——八、组合模式

    目录 java23种设计模式-- 一.设计模式介绍 java23种设计模式-- 二.单例模式 java23种设计模式--三.工厂模式 java23种设计模式--四.原型模式 java23种设计模式-- ...

  6. url_for函数——快速寻找url

    我们已经知道,知道了url就可以找到对应的视图函数,那么现在问题来了,如果我们知道了视图函数,要怎么找到url呢?这时候我们就需要url_for函数了. # coding: utf-8from fla ...

  7. 【Android】AndroidStudio打包apk出现的一些问题 `Error:Execution failed for task ':app:lintVitalRelease'.

    作者:程序员小冰,CSDN博客:http://blog.csdn.net/qq_21376985, QQ986945193 公众号:程序员小冰 1,错误代码: `Error:Execution fai ...

  8. Rakefile

    Rakefile https://www.jianshu.com/p/b18a6e42455a RAKE – Ruby Make http://docs.seattlerb.org/rake/ bun ...

  9. SQL SERVER管理维护计划错误,备份错误,1053/3041/错误18204,严重性16,状态1

    在sqlserv2008/2012里设置了管理-维护计划-备份计划,前些天遇到报错-1053/3041/错误18204,严重性16,状态1等:分享下解决方法. 1.在服务器执行任务报错 2.解决办法 ...

  10. Django 入门介绍

    Django介绍 Django框架是PythonWeb三大主流框架之一,以其功能强大全面而受到众多开发者追捧,现如今Django已经更新到3版本,但是并不推荐使用,更多建议使用1版本. Django版 ...