热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

自定义指令控制两位小数显示,接口Interface和TS解构

2019独角兽企业重金招聘Python工程师标准自定义指令需求:在表单提交时textnumber的输入框必须以两位小数点显示,即输入1010

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

自定义指令

需求:在表单提交时text="number"的输入框必须以两位小数点显示,即输入10 => 10.00, 10.1234 => 10.12。

难点:双向数据绑定[(ngModal)]="value",不支持对值的操作,即不能使用管道去控制。

then,下面的自定义指令customDecimal是通过获取元素本身的value进行操作,再赋值回给元素本身实现

import { Directive, Input, ElementRef, Renderer2, AfterViewInit } from '@angular/core';
import { CommonModule, DecimalPipe } from "@angular/common";@Directive({selector: '[customDecimal]'
})
export class DecimalDirective implements AfterViewInit {// 括号里是dom输入的名字,括号后面是别名,方便操作而已@Input('customDecimal')customDecimal: any;// el,获取该元素集合,rd2,dom的方法属性集合(Renderer没有监听事件),decimalPipe,小数管道constructor(public el: ElementRef, public rd2: Renderer2, public decimalPipe: DecimalPipe) {}ngAfterViewInit() {// listen为angular封装的一些操作dom的集合,详情看对应的接口this.rd2.listen(this.el.nativeElement, 'blur', (e) => {let v = e.srcElement.value;if (v && +v) {// 这里的this指的是DecimalDirective指令,要获得指令控制的元素必须让dom传一个模板变量进来let value = this.customDecimal.value;value = this.decimalPipe.transform(v, '1.2-2');// 由于number类型的输入框,在输入3位整数以上会出现逗号// 管道转换3位整数以上会出现逗号分隔this.customDecimal.value = Array.from(value).map((val, i) => {return (val === ',') ? '' : val;}).join('');} else {return;}})}
}

HTML

必须传入模板变量#ipt

---------------

接口Interface

接口是强控制对象属性,像结构语法,VO只是一个对象用来方便对接

这是typeScript的结构方法:   ({title: string, name: string}) => {}

实际传进来的参数对象不止title 和 name两个属性, 但ts只会描述这两个属性,其他忽略,这就是接口的作用,固化对象属性值

TS中的解构和接口是两码事

这里就不解释解构是什么,TS官网更详尽。

刚开始接触解构和接口的时候,老是想尝试用解构或者接口搞一番优秀代码,但自己理解错误,老认为解构就是接口的写法,也是可以达到过滤数据的。像例子1

let data = {name: 'name', age: 10};
// 我一直以为这样就可以定义接口,对data作简单过滤
let obj: {name} = data;

解构基本用法

let {name, age} = {name: 'hu', age: 10};/*结果
name => 'hu'
age => 10
*/

接口基本用法

interface person {name: string,age: number
}let fn = function(obj: person): void{console.log(obj);
}fn({name: 'hu', age: 10, sex: 'male'}); // {name: 'hu', age: 10} 过滤了sex

误区:不要以为{xxx,  xxx}就是接口,像例子1,是JS的赋值操作,并没有什么过滤控制,最常见的接口过滤就是在方法中传参数,才能过滤。赋值操作并不能达到过滤效果。

 

谈一下implements 和extend

Renderer2抽象类提供的属性和方法


转:https://my.oschina.net/u/2949632/blog/1501655



推荐阅读
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • 合并列值-合并为一列问题需求:createtabletab(Aint,Bint,Cint)inserttabselect1,2,3unionallsel ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 展开全部下面的代码是创建一个立方体Thisexamplescreatesanddisplaysasimplebox.#Thefirstlineloadstheinit_disp ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 深入理解CSS中的margin属性及其应用场景
    本文主要介绍了CSS中的margin属性及其应用场景,包括垂直外边距合并、padding的使用时机、行内替换元素与费替换元素的区别、margin的基线、盒子的物理大小、显示大小、逻辑大小等知识点。通过深入理解这些概念,读者可以更好地掌握margin的用法和原理。同时,文中提供了一些相关的文档和规范供读者参考。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 【shell】网络处理:判断IP是否在网段、两个ip是否同网段、IP地址范围、网段包含关系
    本文介绍了使用shell脚本判断IP是否在同一网段、判断IP地址是否在某个范围内、计算IP地址范围、判断网段之间的包含关系的方法和原理。通过对IP和掩码进行与计算,可以判断两个IP是否在同一网段。同时,还提供了一段用于验证IP地址的正则表达式和判断特殊IP地址的方法。 ... [详细]
  • EzPP 0.2发布,新增YAML布局渲染功能
    EzPP发布了0.2.1版本,新增了YAML布局渲染功能,可以将YAML文件渲染为图片,并且可以复用YAML作为模版,通过传递不同参数生成不同的图片。这个功能可以用于绘制Logo、封面或其他图片,让用户不需要安装或卸载Photoshop。文章还提供了一个入门例子,介绍了使用ezpp的基本渲染方法,以及如何使用canvas、text类元素、自定义字体等。 ... [详细]
  • Python操作MySQL(pymysql模块)详解及示例代码
    本文介绍了使用Python操作MySQL数据库的方法,详细讲解了pymysql模块的安装和连接MySQL数据库的步骤,并提供了示例代码。内容涵盖了创建表、插入数据、查询数据等操作,帮助读者快速掌握Python操作MySQL的技巧。 ... [详细]
author-avatar
JQLNo1xinfinite
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有