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 相关文章推荐
通过Unicode转义序列来加密,按你说的可以算是混淆吧
May 06 Javascript
javascript下给元素添加事件的方法与代码
Aug 13 Javascript
THREE.JS入门教程(1)THREE.JS使用前了解
Jan 24 Javascript
javascript+canvas制作九宫格小程序
Dec 28 Javascript
jquery中animate的stop()方法作用实例分析
Jan 30 Javascript
Spring mvc 接收json对象
Dec 10 Javascript
详解javascript实现瀑布流绝对式布局
Jan 29 Javascript
javascript 中的try catch应用总结
Apr 01 Javascript
windows下vue-cli导入bootstrap样式
Apr 25 Javascript
JavaScript实现body内任意节点的自定义属性功能示例
Sep 18 Javascript
JavaScript中关于class的调用方法
Nov 28 Javascript
VUE实现移动端列表筛选功能
Aug 23 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
深入php多态的实现详解
2013/06/09 PHP
WordPress过滤垃圾评论的几种主要方法小结
2016/07/11 PHP
不常用但很实用的PHP预定义变量分析
2019/06/25 PHP
toString()一个会自动调用的方法
2010/02/08 Javascript
extjs中grid中嵌入动态combobox的应用
2011/01/01 Javascript
jQuery 阴影插件代码分享
2012/01/09 Javascript
window.print打印指定div指定网页指定区域的方法
2014/08/04 Javascript
jQuery实现购物车计算价格功能的方法
2015/03/25 Javascript
jquery使整个div区域可以点击的方法
2015/06/24 Javascript
javascript判断复选框是否选中的方法
2015/10/16 Javascript
JavaScript判断用户名和密码不能为空的实现代码
2016/05/16 Javascript
jQuery控制文本框只能输入数字和字母及使用方法
2016/05/26 Javascript
jQuery简单入门示例之用户校验demo示例
2016/07/09 Javascript
jQuery实现的鼠标滚轮控制图片缩放功能实例
2017/10/14 jQuery
Angular学习教程之RouterLink花式跳转
2018/05/03 Javascript
微信jssdk逻辑在vue中的运用详解
2018/11/14 Javascript
超详细动手搭建一个VuePress 站点及开启PWA与自动部署的方法
2019/01/27 Javascript
最简单的vue消息提示全局组件的方法
2019/06/16 Javascript
Vue使用mixin分发组件的可复用功能
2019/09/01 Javascript
[16:56]教你分分钟做大人:司夜刺客
2014/10/30 DOTA
[06:07]DOTA2-DPC中国联赛3月5日Recap集锦
2021/03/11 DOTA
Python模块结构与布局操作方法实例分析
2017/07/24 Python
python中virtualenvwrapper安装与使用
2018/05/20 Python
TensorFlow Session会话控制&amp;Variable变量详解
2018/07/30 Python
Empty test suite.(PyCharm程序运行错误的解决方法)
2018/11/30 Python
对pyqt5多线程正确的开启姿势详解
2019/06/14 Python
python使用writerows写csv文件产生多余空行的处理方法
2019/08/01 Python
Django之模板层的实现代码
2019/09/09 Python
PyQt5实现画布小程序
2020/05/30 Python
购买大码女装:Lane Bryant
2016/09/07 全球购物
英国第一职业高尔夫商店:Clickgolf.co.uk
2020/11/18 全球购物
放飞梦想演讲稿
2014/05/05 职场文书
晚会开幕词范文
2016/03/04 职场文书
考生诚信考试承诺书(2016版)
2016/03/25 职场文书
Python可视化学习之matplotlib内置单颜色
2022/02/24 Python
Python+Tkinter打造签名设计工具
2022/04/01 Python