/**
*数字控件
*带大写提示,和千分位
**/
Ext.define(appNameSpace+'.utils.MoneyField', {
extend : 'Ext.form.field.Text',
alias : 'widget.moneyfield',
initComponent : function() {
var me = this;
Ext.apply(Ext.form.field.VTypes, {
regexMoney: function(val, field) {
val = val.replace(/,/g,'');
if(isNaN(Number(val))){
if(field.negative_Text && val.indexOf("-")== 0 && val.replace(/-/g,"").length == val.length-1){
return true
}else{
return false;
}
}else{
return true;
}
},
regexMoneyText: "请输入数字,最大保留两位小数!"
});
me.on('keypress',function(t,e){
if(t.value.indexOf(".") != -1 && e.keyCode == 46){
e.stopEvent();
}
if((!t.negative_Text) && (44>e.keyCode && e.keyCode>58)){
e.stopEvent();
}else if((t.negative_Text) && (45>e.keyCode && e.keyCode>58)){
e.stopEvent();
} });
me.on("mouseover",function(){console.log("123")})
// Ext.apply(me,{});
this.callParent(arguments); // 调用你模块的initComponent函数
},
baseChars: '0123456789.-',
maskRe :new RegExp('[-0-9\.]'),
fieldStyle:"text-align:right;",
enableKeyEvents:true,
cursor:null,
vtype:"regexMoney",
getTip: function() {
var tip = this.tip;
if (!tip) {
tip = this.tip = Ext.widget('tooltip', {
target: this.el,
width: 420,
autoHide: false,
anchor: 'top',
//closable: true,
mouseOffset: [100, -2],
constrainPosition: false
});
tip.show();
}
return tip;
},
getValue: function(flag) {
var me = this,
val = me.rawToValue(me.processRawValue(me.getRawValue()));
// me.value = val;
if(!flag){
val = val.replace(/,/g,'');
}
return val;
},
onChange:function(newVal, oldVal){
/*if(value.replace(/,/g,'') == oldVal.replace(/,/g,'')){
if(newVal.length < oldVal.length){
for(var i=0;i<oldVal.length;i++){
if(newVal[i] != oldVal[i]){
this.setValue(this.toThousands(value));
}
}
}else{
return;
}
}*/
var t = this;
if(isNaN(Number(newVal.replace(/,/g,'')))){
if(t.negative_Text && newVal.indexOf("-")==0 && newVal.replace(/-/g,"").length == newVal.length-1){
return
}else{
this.setValue("");
return;
}
}
if(!t.isValid()){
return;
}
var el = this.inputEl.dom;
/**数字大写**/
if(newVal==oldVal){
return;
}
var decimal = "";
var value = newVal;
/*if(newVal.indexOf(".") != -1){
if(newVal.substring(value.indexOf(".")+1).indexOf(".") != -1){
this.setValue(oldVal);
return;
}
}*/
if(newVal.indexOf(",") != -1){
value = newVal.replace(/,/g,'');
if(newVal.replace(/,/g,'') == oldVal.replace(/,/g,'')){
return;
}
} var tip = this.getTip();
t.setValue(t.getValue(true).replace(/\s/g, ""));
t.setValue(t.getValue(true).replace(/。/g, "."));
if(t.value != null && t.value != ''){
tip.setDisabled(false);
tip.setTitle(atoc(value));
tip.show();
}else{
tip.setDisabled(true);
tip.hide();
}
/**千分位**/
if(newVal == ""){
return;
} if(value.indexOf(".") != -1){
var valLength = value.substring(value.indexOf(".")).length;
if(valLength == 1){
decimal = ".";
}else{
decimal = value.substring(value.indexOf("."));
}
value = value.substring("0",value.indexOf("."));
}
var n_ = "";
if(this.negative_Text && value.indexOf("-")==0){
value = value.replace(/-/g,'');
n_ = "-"
}
this.setValue(n_ + this.toThousands(value,newVal)+decimal);
el.setSelectionRange(this.cursor,this.cursor);
return;
},
onBlur:function(e){
var me = this;
if(!me.isValid()){
return;
}
var val = me.getValue(true);
/**数字大写**/
var tip = this.getTip();
tip.setDisabled(true);
tip.hide();
/**小数位**/
var value = val.replace(/,/g,'');
if(val.indexOf(".") != -1){
value = parseFloat(value).toFixed(2);
var sVal = val.substring(0,val.indexOf("."));
var eVal = value.substring(value.indexOf("."));
var n_ = "";
if(this.negative_Text && value.indexOf("-")==0){
value = value.replace(/-/g,'');
n_ = "-"
}
me.setValue(n_ + this.toThousands(sVal)+eVal);
}else{
if(val != ""){
me.setValue(this.toThousands(value));
}
}
return;
},
onFocus:function(e){
var me = this;
var el = this.inputEl.dom;
el.setAttribute("onpaste","return false");
var val = me.getValue(true);
var newVal = val;
/**数字大写**/
var t = this;
if(!t.isValid()){
return;
}
var tip = this.getTip();
t.newVal = t.value;
t.setValue(t.getValue(true).replace(/\s/g, ""));
t.setValue(t.getValue(true).replace(/。/g, "."));
if(t.value != null && t.value != ''){
tip.setDisabled(false);
tip.setTitle(atoc(newVal));
tip.show();
}else{
tip.setDisabled(true);
tip.hide();
}
me.getValue(true);
return;
},
toThousands:function(num,val) {
var el = this.inputEl.dom;
var value = this.value;
if(num.indexOf(",") != -1){
num = num.replace(/,/g,'');
}
var str = el.selectionStart;
var num = (num || 0).toString(), result = '';
while (num.length > 3) {
result = ',' + num.slice(-3) + result;
num = num.slice(0, num.length - 3);
}
if (num) { result = num + result; }
//光标在最后的时候
if(str == value.length && value.indexOf(".")==-1){
this.cursor = result.length;
}else if((result.length - value.length == 1 && value.indexOf(".")==-1)||(result.length - value.substring(0,value.indexOf(".")).length==1 && value.indexOf(".") !=-1)){
this.cursor = str+1;
}else if(result.length - value.length == -1 && value.indexOf(".")==-1||(result.length - value.substring(0,value.indexOf(".")).length==-1 && value.indexOf(".") !=-1)){
this.cursor = str-1;
}else if(result.length == value.length && value.indexOf(".")==-1){
this.cursor = str;
}else if(str == value.length && value.indexOf(".") !=-1){
this.cursor = value.length;
}else if(value.indexOf(".") !=-1 ){
this.cursor = str;
}
if(this.negative_Text && value.indexOf("-")==0){
this.cursor = this.cursor+1
}
/*if(str == val.length &&val.indexOf(".") == -1){
this.cursor = result.length;
}else if(str == val.length &&val.indexOf(".") != -1){
var num = val.substring(val.indexOf(".")).length;
this.cursor = result.length + num;
}else if(str == this.value.length){
this.cursor = str;
}*/
return result;
}
});

ext 扩展控件—moneyField的更多相关文章

  1. 多年前写的文本框扩展控件(有ValueChanging事件等),已放github

    本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 阅读目录 介绍 起因 代码 使用 GitHub ...

  2. JavaFX的扩展控件库ControlsFX介绍

    声明:   本博客文章原创类别的均为个人原创,版权所有.转载请注明出处: http://blog.csdn.net/ml3947,另外本人的个人博客:http://www.wjfxgame.com. ...

  3. WPF自定义控件(三)の扩展控件

    扩展控件,顾名思义就是对已有的控件进行扩展,一般继承于已有的原生控件,不排除继承于自定义的控件,不过这样做意义不大,因为既然都自定义了,为什么不一步到位呢,有些不同的需求也可以通过此来完成,不过类似于 ...

  4. 2.C#Panel扩展控件

    1.解决方案下添加新建项目新建类库 2. 在项目下添加新建项选择新建组件类 3.先引用,然后导入两个命名空间 4.因为是扩展控件,把继承自Component改成继承自Panel using Syste ...

  5. 验证控件插图扩展控件ValidatorCalloutExtender(用于扩展验证控件)和TextBoxWatermarkExtender

    <asp:ScriptManager ID="ScriptManager1" runat="server">  </asp:ScriptMan ...

  6. Ext.net控件调整后台事件、方法论

    一.以ext.net的button为例调用后台事件: 前台代码: <ext:Button ID="Button1" runat="server" Text ...

  7. Ext表格控件

    表格控件其实也就是帮我们完成了数据的填充工作而已,具体的数据源.要显示的列,列的定制.数据源中的哪条数据显示在哪个列中等属性还是需要我们自己手动配置的,所以我们分下面几步来完成网格控件的数据绑定: 1 ...

  8. IExtenderProvider,c#组件扩展控件属性

    [ProvideProperty("IsEnabled", typeof(LayoutControlItem)), ToolboxItemFilter("System.W ...

  9. QGEditors.WinForms WinForms下使用的部分扩展控件

    Nuget: https://www.nuget.org/packages/QGEditors.WinForms/ PM> Install-Package QGEditors.WinForms ...

随机推荐

  1. 【转】Flask快速入门

    迫不及待要开始了吗?本页提供了一个很好的 Flask 介绍,并假定你已经安装好了 Flask.如果没有,请跳转到 安装 章节. 一个最小的应用 一个最小的 Flask 应用看起来会是这样: from ...

  2. Power of Cryptography

    //只用一行核心代码就可以过的天坑题目............= = 题目: Description Current work in cryptography involves (among othe ...

  3. typeahead使用配置参数。

    示例代码: var suggestion_source = new Bloodhound({ datumTokenizer: Bloodhound.tokenizers.obj.whitespace( ...

  4. having的用法以及与where区别介绍

    having子句可以让我们筛选成组后的各种数据,having子句在查询过程中慢于聚合语句,接下来通过实例介绍下,感兴趣的你可以参考下,希望可以帮助到你 having的用法 having子句可以让我们筛 ...

  5. iOS使用技能 - 短信,语言验证码的获取与验证小结

    最近有学习一个小技能,这里小结一下,分享给大家,互相交流. 首先是大体步骤: 在mob官网注册,然后添加短信验证的应用 使用cocoapods导入框架 Podfile文件: platform :ios ...

  6. Nothing

    破烂的文具盒里,一张十年的纸条子和一袋存了十年的德芙巧克力 浅绿色的纸条子上写是当时你给我抄的作业题目,蓝色清秀的字体 但是十年后,你却已嫁他人 将身后的风雪.夕阳,空气埋葬.窑藏,待非常多年以后酿成 ...

  7. Linux进程间通信——使用数据报套接字

    前一篇文章, Linux进程间通信——使用流套接字介绍了一些有关socket(套接字)的一些基本内容,并讲解了流套接字的使用,这篇文章将会给大家讲讲,数据报套接字的使用. 一.简单回顾——什么是数据报 ...

  8. DATABASE LINK 的查看、创建与删除

    1.查看dblink SELECT OWNER,OBJECT_NAME FROM DBA_OBJECTS WHERE OBJECT_TYPE='DATABASE LINK'; 或者 SELECT * ...

  9. 关于css的兼容

    这篇随笔为了方便自己后期的学习和查找,用来记录平时遇到的一些问题,后期会陆续更新 1.背景图 :background-position属性,在ff下不支持该属性的拆分写法(background-pos ...

  10. 如何通过PS制作图片文字效果

    如图这是最终效果,下面我为大家介绍如何制作这种图片文字效果 准备一张图: 方法,步骤: 首先我们打开PHOTOSHOP,插入一张图片. 之后按键盘上面的"T"键快捷键启用文字工具, ...