sencha touch 输入框验证


Ext.define('User', {
    extend: 'Ext.data.Model',

    config: {
        fields: [
            {name: 'name',     type: 'string'},
            {name: 'age',      type: 'int'},
            {name: 'phone',    type: 'string'},
            {name: 'gender',   type: 'string'},
            {name: 'username', type: 'string'},
            {name: 'alive',    type: 'boolean', defaultValue: true}
        ],

        validations: [
            {type: 'presence',  field: 'age'},
            {type: 'length',    field: 'name',     min: 2},
            {type: 'inclusion', field: 'gender',   list: ['Male', 'Female']},
            {type: 'exclusion', field: 'username', list: ['Admin', 'Operator']},
            {type: 'format',    field: 'username', matcher: /([a-z]+)[0-9]{2,3}/}
        ]
    }
});
在我们运用的框架中,有个公用函数

   /**
     * form 表单验证
     * @param modelName[String] model 全限定名
     * @param json[Json] data
     */
    validateForm: function(modelName, json) {
        var me = this;
        var model = Ext.create(modelName,json), errorMessage='', errors = model.validate();
        if (!errors.isValid()) {
            errors.each(function (err) {
                errorMessage += err.getMessage() + '<br/>';
                var s = Ext.String.format('field[name={0}]',err.getField());
                //TODO  apply the style class by lyf
                me.down(s).element.select('input').addCls('red_background');
                setTimeout(function(){me.down(s).element.select('input').removeCls('red_background');},2000);
            });
            Ext.Msg.alert('提交的表单有错误!', errorMessage);
            return true;
        } 
        return false;
    }

运用的时候直接在controller中调用就可以了

      json = Ext.apply(button.up('formpanel').getValues());// 传递到后台的参数
        
         if(view.validateForm('modelName', json)) {
                return false;
            }



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值