angular4应用中输入的最小值和最大值的方法


Posted in Javascript onMay 17, 2019

Angular4输入属性

输入属性通常用于父组件向子组件传递信息

举个栗子:我们在父组件向子组件传递股票代码,这里的子组件我们叫它app-order

首先在app.order.component.ts中声明需要由父组件传递进来的值

order.component.ts

...

@Input()

stockCode: string

@Input()

amount: string

...

order.component.html

<p>这里是子组件</p>

<p>股票代码为{{stockCode}}</p>

<p>股票总数为{{amount}}</p>

然后我们需要在父组件(app.component)中向子组件传值

app.component.ts

...

stock: string

...

app.component.html

<input type="text" placeholder="请输入股票代码" [(ngModel)]="stock">

<app-order [stockCode]="stock" [amount]="100"></app-order>

这里我们使用了Angular的双向数据绑定,将用户输入的值和控制器中的stock进行绑定。然后传递给子组件,子组件接收后在页面显示。

Angular4输出属性

当子组件需要向父组件传递信息时需要用到输出属性。

举个栗子:当我们从股票交易所获得股票的实时价格时,希望外部也可以得到这个信息。为了方便,这里的实时股票价格我们通过一个随机数来模拟。这里的子组件我们叫它app.price.quote

使用EventEmitter从子组件向外发射事件

price.quote.ts

export class PriceQuoteComponent implements OnInit{

 stockCode: string = 'IBM';

 price: number;

 //使用EventEmitter发射事件

 //泛型是指往外发射的事件是什么类型

 //priceChange为事件名称

 @Output()

 priceChange:EventEmitter<PriceQuote> = new EventEmitter();

 constructor(){

 setInterval(() => {

  let priceQuote = new PriceQuote(this.stockCode, 100*Math.random());

  this.price = priceQuote.lastPrice;

  //发射事件

  this.priceChange.emit(priceQuote);

 })

 }

 ngInit(){

 }

}

//股票信息类

//stockCode为股票代码,lastPrice为股票价格

export class PriceQuote{

 constructor(public stockCode:string,

  public lastPrice:number

 )

}

price.quote.html

<p>

 这里是报价组件

</p>

<p>

 股票代码是{{stockCode}}

</p>

<p>

 股票价格是{{price | number:'2.2-2'}}

</p>

接着我们在父组件中接收事件

app.component.html

<app-price-quote (priceChange)="priceQuoteHandler($event)"></app-price-quote>

<p>

 这是在报价组件外, 股票代码是{{priceQuote.stokcCode}},

 股票价格是{{priceQuote.lastPrice | number:'2.2-2'}}

</p>

事件绑定和原生的事件绑定是一样的,都是将事件名称放在()中。

app.component.ts

export class AppComponent{

 priceQuote:PriceQuote = new PriceQuote('', 0);

 priceQuoteHandler(event:PriceQuote){

 this.priceQuote = event;

 }

}

这里的event类型就是子组件传递事件的类型。

angular4应用中输入的最小值和最大值的方法

我有一个带有表单的angular4应用程序.在这个我输入一个百分比输入.所以,我想用0到100之间的值来阻止输入.

我试图添加min =“0”和max =“100”,但我仍然可以输入一个高于100或小于0的数字.

模板

<md-input-container>
 <input type="number" 
  maxlength="3" 
  min="0" 
  max="100" 
  required 
  mdInput 
  placeholder="Charge" 
  [(ngModel)]="rateInput" 
  name="rateInput">
 <md-error>Required field</md-error>
</md-input-container>

你知道我怎么做吗?

解决方法

我成功地使用了表单控件.

这是我的HTML代码:

<md-input-container>
    <input type="number" min="0" max="100" required mdInput placeholder="Charge" [(ngModel)]="rateInput" name="rateInput" [formControl]="rateControl">
    <md-error>Please enter a value between 0 and 100</md-error>
  </md-input-container>

在我的打字稿代码中,我有:

this.rateControl = new FormControl("",[Validators.max(100),Validators.min(0)])

因此,如果我们输入的值大于100或小于0,则材料设计输入变为红色且该字段未验证.所以之后,如果值不好,我点击保存按钮时就不保存.

总结

以上是三水点靠木为你收集整理的angular4应用中输入的最小值和最大值全部内容,希望文章能够帮你解决angular4应用中输入的最小值和最大值所遇到的程序开发问题。

Javascript 相关文章推荐
Prototype使用指南之dom.js
Jan 10 Javascript
javascript之querySelector和querySelectorAll使用说明
Oct 09 Javascript
jQuery setTimeout()函数使用方法
Apr 07 Javascript
关于jQuery $.isNumeric vs. $.isNaN vs. isNaN
Apr 15 Javascript
JQuery Tips相关(1)----关于$.Ready()
Aug 14 Javascript
jquery渐隐渐显的图片幻灯闪烁切换实现方法
Feb 26 Javascript
JS组件Bootstrap Table使用实例分享
May 30 Javascript
JS自定义函数对web前端上传的文件进行类型大小判断
Oct 19 Javascript
微信小程序云开发之使用云存储
May 17 Javascript
关于layui的动态图标不显示的解决方法
Sep 04 Javascript
VUE+elementui面包屑实现动态路由详解
Nov 04 Javascript
javascript 原型与原型链的理解及应用实例分析
Feb 10 Javascript
jQuery实现的点击显示隐藏下拉菜单功能完整示例
May 17 #jQuery
详解 微信小程序开发框架(MINA)
May 17 #Javascript
Vue模板语法中数据绑定的实例代码
May 17 #Javascript
jQuery控制input只能输入数字和两位小数的方法
May 16 #jQuery
微信小程序云开发详细教程
May 16 #Javascript
atom-design(Vue.js移动端组件库)手势组件使用教程
May 16 #Javascript
小程序scroll-view安卓机隐藏横向滚动条的实现详解
May 16 #Javascript
You might like
mysql 中InnoDB和MyISAM的区别分析小结
2008/04/15 PHP
PHP5 字符串处理函数大全
2010/03/23 PHP
SESSION存放在数据库用法实例
2015/08/08 PHP
php使用CURL模拟GET与POST向微信接口提交及获取数据的方法
2016/09/23 PHP
Vagrant(WSL)+PHPStorm+Xdebu 断点调试环境搭建
2019/12/13 PHP
匹配任意字符的正则表达式写法
2010/04/29 Javascript
JS实现自动固定顶部的悬浮菜单栏效果
2015/09/16 Javascript
Javascript类型转换的规则实例解析
2016/02/23 Javascript
jQuery实现内容定时切换效果完整实例
2016/04/06 Javascript
BootstrapTable请求数据时设置超时(timeout)的方法
2017/01/22 Javascript
canvas压缩图片转换成base64格式输出文件流
2017/03/09 Javascript
Vue Ajax跨域请求实例详解
2017/06/20 Javascript
js学习总结之DOM2兼容处理顺序问题的解决方法
2017/07/27 Javascript
vue2.0+vue-dplayer实现hls播放的示例
2018/03/02 Javascript
fetch 如何实现请求数据
2018/12/20 Javascript
vue通信方式EventBus的实现代码详解
2019/06/10 Javascript
vue.js中导出Excel表格的案例分析
2019/06/11 Javascript
JS使用正则表达式提交页面验证的代码
2019/10/16 Javascript
Python格式化css文件的方法
2015/03/10 Python
Python自动化开发学习之三级菜单制作
2017/07/14 Python
利用python实现简单的邮件发送客户端示例
2017/12/23 Python
Python实现的读取/更改/写入xml文件操作示例
2018/08/30 Python
提升Python效率之使用循环机制代替递归函数
2019/07/23 Python
使用Python爬虫库requests发送请求、传递URL参数、定制headers
2020/01/25 Python
学会python自动收发邮件 代替你问候女友
2020/05/20 Python
解决Keras中循环使用K.ctc_decode内存不释放的问题
2020/06/29 Python
利用CSS3实现平移动画效果示例代码
2016/10/12 HTML / CSS
美体小铺英国官网:The Body Shop英国
2017/01/24 全球购物
Burberry英国官网:英国标志性奢侈品牌
2017/03/29 全球购物
班级安全教育实施方案
2014/02/23 职场文书
委托书怎样写
2014/08/30 职场文书
2014年房地产工作总结范文
2014/11/19 职场文书
《抽屉原理》教学反思
2016/02/20 职场文书
实习报告怎么写
2019/06/20 职场文书
Python绘制散乱的点构成的图的方法
2022/04/21 Python
前端传参数进行Mybatis调用mysql存储过程执行返回值详解
2022/08/14 MySQL