Java Blog for Alex Wan

Let life be beautiful like summer flowers and death like autumn leaves.

统计

留言簿(10)

BlogJava

Blogs

DIV+CSS

JQuery相关

友情链接

常去的地方

数据供应

阅读排行榜

评论排行榜

[Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本

背景:
在Extjs论坛上找到的日期时间控件()是由Extjs2.0原版的日期控件和时间控件组合而成,在提示验证信息的时候很容易出错,而且验证信息显示位置也不对.
做法:
基于以上背景,我对日期时间控件进行了改进,主要的做法是:
(1)重载基础的日期控件和时间控件,用于组合新的日期时间控件
(2)在日期时间控件中添加消息栈,用于存储信息记录
代码:
Ext.ux.TimeField(之前遗漏了这个控件的代码)
Ext.ux.TimeField=function(config)
{
    
//be true when reset

    
this.dateTime=config.dateTime;
    Ext.ux.TimeField.superclass.constructor.call(
this,config);
}
;

Ext.extend(Ext.ux.TimeField,Ext.form.TimeField, 
{
     
     
/**
     * Clear any invalid styles/messages for this field
     
*/

    clearInvalid : 
function(){
        
if(!this.rendered || this.preventMark)// not rendered
            return;
        }

        
this.el.removeClass(this.invalidClass);
        
this.dateTime.clearInvalid();
        
//check the other field for datetime
        //this.dateTime.df.isValid();
        
    }
,
    
/**
     * Mark this field as invalid
     * @param {String} msg The validation message
     
*/

    markInvalid : 
function(msg){
        
if(!this.rendered || this.preventMark)// not rendered
            return;
        }

        
this.el.addClass(this.invalidClass);
        msg 
= msg || this.invalidText;
        
this.dateTime.markInvalid(msg);
    }

   
    
}
);

Ext.ux.DateField
Ext.ux.DateField=function(config)
{
    
//be true when reset
    this.isReset=false;
    
this.dateTime=config.dateTime;
    Ext.ux.DateField.superclass.constructor.call(
this,config);
}
;
 Ext.extend(Ext.ux.DateField,Ext.form.DateField,  
{
     
     
/**
     * Clear any invalid styles/messages for this field
     
*/

    clearInvalid : 
function(){
        
if(!this.rendered || this.preventMark)// not rendered
            return;
        }

        
this.el.removeClass(this.invalidClass);
         
this.dateTime.clearInvalid();
         
//check the other field for datetime
        
        
// this.dateTime.tf.isValid();
    }
,
    
/**
     * Mark this field as invalid
     * @param {String} msg The validation message
     
*/

    markInvalid : 
function(msg){
        
if(!this.rendered || this.preventMark)// not rendered
            return;
        }

        
this.el.addClass(this.invalidClass);
        msg 
= msg || this.invalidText;
         
this.dateTime.markInvalid(msg);
    }

   
}
)

Ext.ux.DateTime
Ext.ux.DateTime = function(config) {

 
// create DateField
 
 
//message stack
 this.messages=new Array();
 
var dateTime=this;
        
var dateConfig = Ext.apply({}{
             name:config.name 
+ '-date'
            ,format:config.dateFormat 
|| Ext.form.DateField.prototype.format
            ,width:config.dateWidth
            ,selectOnFocus:config.selectOnFocus
            ,dateTime:dateTime
            ,listeners:
{
                  blur:
{scope:this, fn:this.onBlur}
                 ,focus:
{scope:this, fn:this.onFocus}
            }

        }
, config.dateConfig);
        
this.df = new Ext.ux.DateField(dateConfig);
       

        
// create TimeField
        var timeConfig = Ext.apply({}{
             name:config.name 
+ '-time'
            ,format:config.timeFormat 
|| Ext.form.TimeField.prototype.format
            ,width:config.timeWidth
            ,selectOnFocus:config.selectOnFocus
            ,dateTime:dateTime
            ,listeners:
{
                  blur:
{scope:this, fn:this.onBlur}
                 ,focus:
{scope:this, fn:this.onFocus}
            }

        }
, config.timeConfig);
        
this.tf = new Ext.ux.TimeField(timeConfig);
        Ext.ux.DateTime.superclass.constructor.call(
this,config);
        
        
}
;


Ext.ux.DateTime
Ext.extend(Ext.ux.DateTime ,Ext.form.Field, {
    
/**
     * @cfg {String/Object} defaultAutoCreate DomHelper element spec
     * Let superclass to create hidden field instead of textbox. Hidden will be submittend to server
     
*/

     defaultAutoCreate:
{tag:'input', type:'hidden'}
    
/**
     * @cfg {Number} timeWidth Width of time field in pixels (defaults to 100)
     
*/

    ,timeWidth:
100
    
/**
     * @cfg {String} dtSeparator Date - Time separator. Used to split date and time (defaults to ' ' (space))
     
*/

    ,dtSeparator:' '
    
/**
     * @cfg {String} hiddenFormat Format of datetime used to store value in hidden field
     * and submitted to server (defaults to 'Y-m-d H:i:s' that is mysql format)
     
*/

    ,hiddenFormat:'Y
-m-d H:i:s'
    
/**
     * @cfg {Boolean} otherToNow Set other field to now() if not explicly filled in (defaults to true)
     
*/

    ,otherToNow:
true
    
/**
     * @cfg {Boolean} emptyToNow Set field value to now if on attempt to set empty value.
     * If it is true then setValue() sets value of field to current date and time (defaults to false)
    /**
     * @cfg {String} timePosition Where the time field should be rendered. 'right' is suitable for forms
     * and 'bellow' is suitable if the field is used as the grid editor (defaults to 'right')
     
*/

    ,timePosition:'right' 
// valid values:'bellow', 'right'
    /**
     * @cfg {String} dateFormat Format of DateField. Can be localized. (defaults to 'm/y/d')
     
*/

    ,dateFormat:'m
/d/y'
    
/**
     * @cfg {String} timeFormat Format of TimeField. Can be localized. (defaults to 'g:i A')
     
*/

    ,timeFormat:'g:i A'
    
/**
     * @cfg {Object} dateConfig Config for DateField constructor.
     
*/

    
/**
     * @cfg {Object} timeConfig Config for TimeField constructor.
     
*/


    
// {{{
    /**
     * private
     * creates DateField and TimeField and installs the necessary event handlers
     
*/

    ,initComponent:
function() {
        
// call parent initComponent
        Ext.ux.DateTime.superclass.initComponent.call(this);
        
// relay events
        this.relayEvents(this.df, ['focus', 'specialkey', 'invalid', 'valid']);
        
this.relayEvents(this.tf, ['focus', 'specialkey', 'invalid', 'valid']);


    }
 // eo function initComponent
    // }}}
    // {{{
    /**
     * private
     * Renders underlying DateField and TimeField and provides a workaround for side error icon bug
     
*/

    ,onRender:
function(ct, position) {
        
// don't run more than once
        if(this.isRendered) {
            
return;
        }


        
// render underlying hidden field
        Ext.ux.DateTime.superclass.onRender.call(this, ct, position);

        
// render DateField and TimeField
        // create bounding table
        var t;
        
if('bellow' === this.timePosition) {
            t 
= Ext.DomHelper.append(ct, {tag:'table',style:'border-collapse:collapse',children:[
                 
{tag:'tr',children:[{tag:'td', style:'padding-bottom:1px', cls:'ux-datetime-date'}]}
                ,
{tag:'tr',children:[{tag:'td', cls:'ux-datetime-time'}]}
            ]}
true);
        }

        
else {
            t 
= Ext.DomHelper.append(ct, {tag:'table',style:'border-collapse:collapse',children:[
                
{tag:'tr',children:[
                    
{tag:'td',style:'padding-right:4px', cls:'ux-datetime-date'},{tag:'td', cls:'ux-datetime-time'}
                ]}

            ]}
true);
        }


        
this.tableEl = t;
        
this.wrap = t.wrap({cls:'x-form-field-wrap'});
        
this.wrap.on("mousedown"this.onMouseDown, this{delay:10});

        
// render DateField & TimeField
        this.df.render(t.child('td.ux-datetime-date'));
        
this.tf.render(t.child('td.ux-datetime-time'));

        
// workaround for IE trigger misalignment bug
        if(Ext.isIE && Ext.isStrict) {
            t.select('input').applyStyles(
{top:0});
        }


        
this.on('specialkey', this.onSpecialKey, this);
        
this.df.el.swallowEvent(['keydown', 'keypress']);
        
this.tf.el.swallowEvent(['keydown', 'keypress']);

        
// create icon for side invalid errorIcon
        if('side' === this.msgTarget) {
            
var elp = this.el.findParent('.x-form-element', 10true);
            
this.errorIcon = elp.createChild({cls:'x-form-invalid-icon'});

            
this.df.errorIcon = this.errorIcon;
            
this.tf.errorIcon = this.errorIcon;
        }

        
        
// we're rendered flag
        this.isRendered = true;

    }
 // eo function onRender
    // }}}
    // {{{
    /**
     * private
     
*/

    ,adjustSize:Ext.BoxComponent.prototype.adjustSize
    
// }}}
    // {{{
    /**
     * private
     
*/

    ,alignErrorIcon:
function() {
        
this.errorIcon.alignTo(this.tableEl, 'tl-tr', [20]);
    }

    
// }}}
    // {{{
    /**
     * private initializes internal dateValue
     
*/

    ,initDateValue:
function() {
        
this.dateValue = this.otherToNow ? new Date() : new Date(197001000);
    }

    
// }}}
    // {{{
    /**
     * Disable this component.
     * @return {Ext.Component} this
     
*/

    ,disable:
function() {
        
if(this.isRendered) {
            
this.df.disabled = this.disabled;
            
this.df.onDisable();
            
this.tf.onDisable();
        }

        
this.disabled = true;
        
this.df.disabled = true;
        
this.tf.disabled = true;
        
this.fireEvent("disable"this);
        
return this;
    }
 // eo function disable
    // }}}
    // {{{
    /**
     * Enable this component.
     * @return {Ext.Component} this
     
*/

    ,enable:
function() {
        
if(this.rendered){
            
this.df.onEnable();
            
this.tf.onEnable();
        }

        
this.disabled = false;
        
this.df.disabled = false;
        
this.tf.disabled = false;
        
this.fireEvent("enable"this);
        
return this;
    }
 // eo function enable
    // }}}
    // {{{
    /**
     * private Focus date filed
     
*/

    ,focus:
function() {
        
this.df.focus();
    }
 // eo function focus
    // }}}
    // {{{
    /**
     * private
     
*/

    ,getPositionEl:
function() {
        
return this.wrap;
    }

    
// }}}
    // {{{
    /**
     * private
     
*/

    ,getResizeEl:
function() {
        
return this.wrap;
    }

    
// }}}
    // {{{
    /**
     * @return {Date/String} Returns value of this field
     
*/

    ,getValue:
function() {
        
// create new instance of date
        return this.dateValue ? new Date(this.dateValue) : '';
    }
 // eo function getValue
    // }}}
    // {{{
    /**
     * @return {Boolean} true = valid, false = invalid
     * private Calls isValid methods of underlying DateField and TimeField and returns the result
     
*/

    ,isValid:
function() {
        
return this.df.isValid() && this.tf.isValid();
    }
 // eo function isValid
    // }}}
    // {{{
    /**
     * Returns true if this component is visible
     * @return {boolean} 
     
*/

    ,isVisible : 
function(){
        
return this.df.rendered && this.df.getActionEl().isVisible();
    }
 // eo function isVisible
    // }}}
    // {{{
    /*
     * private Handles blur event
     
*/

    ,onBlur:
function(f) {
        
// called by both DateField and TimeField blur events

        
// revert focus to previous field if clicked in between
        if(this.wrapClick) {
            f.focus();
            
this.wrapClick = false;
        }


        
// update underlying value
        if(f === this.df) {
            
this.updateDate();
        }

        
else {
            
this.updateTime();
        }

        
this.updateHidden();

        
// fire events later
        (function() {
            
if(!this.df.hasFocus && !this.tf.hasFocus) {
                
var v = this.getValue();
                
if(String(v) !== String(this.startValue)) {
                    
this.fireEvent("change"this, v, this.startValue);
                }

                
this.hasFocus = false;
                
this.fireEvent('blur', this);
            }

        }
).defer(100this);

    }
 // eo function onBlur
    // }}}
    // {{{
    /**
     * private Handles focus event
     
*/

    ,onFocus:
function() {
        
if(!this.hasFocus){
            
this.hasFocus = true;
            
this.startValue = this.getValue();
            
this.fireEvent("focus"this);
        }

    }

    
// }}}
    // {{{
    /**
     * private Just to prevent blur event when clicked in the middle of fields
     
*/

    ,onMouseDown:
function(e) {
        
this.wrapClick = 'td' === e.target.nodeName.toLowerCase();
    }

    
// }}}
    // {{{
    /**
     * private
     * Handles Tab and Shift-Tab events
     
*/

    ,onSpecialKey:
function(t, e) {
        
var key = e.getKey();
        
if(key == e.TAB) {
            
if(t === this.df && !e.shiftKey) {
                e.stopEvent();
                
this.tf.focus();
            }

            
if(t === this.tf && e.shiftKey) {
                e.stopEvent();
                
this.df.focus();
            }

        }

        
// otherwise it misbehaves in editor grid
        if(key == e.ENTER) {
            
this.updateValue();
        }


    }
 // eo function onSpecialKey
    // }}}
    // {{{
    /**
     * private Sets the value of DateField
     
*/

    ,setDate:
function(date) {
        
this.df.setValue(date);
    }
 // eo function setDate
    // }}}
    // {{{
    /*
     * private Sets the value of TimeField
     
*/

    ,setTime:
function(date) {
        
this.tf.setValue(date);
    }
 // eo function setTime
    // }}}
    // {{{
    /**
     * private
     * Sets correct sizes of underlying DateField and TimeField
     * With workarounds for IE bugs
     
*/

    ,setSize:
function(w, h) {
        
if(!w) {
            
return;
        }

        
if('bellow' == this.timePosition) {
            
this.df.setSize(w, h);
            
this.tf.setSize(w, h);
            
if(Ext.isIE) {
                
this.df.el.up('td').setWidth(w);
                
this.tf.el.up('td').setWidth(w);
            }

        }

        
else {
            
this.df.setSize(w - this.timeWidth - 4, h);
            
this.tf.setSize(this.timeWidth, h);

            
if(Ext.isIE) {
                
this.df.el.up('td').setWidth(w - this.timeWidth - 4);
                
this.tf.el.up('td').setWidth(this.timeWidth);
            }

        }

    }
 // eo function setSize
    // }}}
    // {{{
    /**
     * @param {Mixed} val Value to set
     * Sets the value of this field
     
*/

    ,setValue:
function(val) {
        
//alert(val.time);
        if(!val && true === this.emptyToNow) {
            
this.setValue(new Date());
            
return;
        }

        
else if(!val) {
            
this.setDate('');
            
this.setTime('');
            
this.updateValue();
            
return;
        }

        val 
= val ? val : new Date(19700 ,1000);
        
var da, time;
        
if(val instanceof Date) {
            
this.setDate(val);
            
this.setTime(val);
            
this.dateValue = new Date(val);
        }
else if(val instanceof Object&&val.time)
        
{
            
var dtDate = new Date(parseInt(val.time));
            
this.setDate(dtDate);
            
this.setTime(dtDate);
            
this.dateValue = new Date(dtDate);
        }

        
else {
            da 
= val.split(this.dtSeparator);
            
this.setDate(da[0]);
            
if(da[1]) {
                
this.setTime(da[1]);
            }

        }

        
this.updateValue();
    }
 // eo function setValue
    // }}}
    // {{{
    /**
     * Hide or show this component by boolean
     * @return {Ext.Component} this
     
*/

    ,setVisible: 
function(visible){
        
if(visible) {
            
            
this.df.show();
            
this.tf.show();

        
        }
else{
            
this.df.hide();
            
this.tf.hide();
        }

        
return this;
    }
 // eo function setVisible
    // }}}
    //{{{
    ,
    reset : 
function(){
        
this.df.reset();
        
this.tf.reset();
        
this.clearInvalid();
    }
,
    show:
function() {

        
return this.setVisible(true);
    }
 // eo function show
    //}}}
    //{{{
    ,hide:function() {
        
        
return this.setVisible(false);
    }
 // eo function hide
    //}}}
    // {{{
    /**
     * private Updates the date part
     
*/

    ,updateDate:
function() {

        
var d = this.df.getValue();
        
if(d) {
            
if(!(this.dateValue instanceof Date)) {
                
this.initDateValue();
                
if(!this.tf.getValue()) {
                    
this.setTime(this.dateValue);
                }

            }

            
this.dateValue.setMonth(0); // because of leap years
            this.dateValue.setFullYear(d.getFullYear());
            
this.dateValue.setMonth(d.getMonth());
            
this.dateValue.setDate(d.getDate());
        }

        
else {
            
this.dateValue = '';
            
this.setTime('');
        }

    }
 // eo function updateDate
    // }}}
    // {{{
    /**
     * private
     * Updates the time part
     
*/

    ,updateTime:
function() {
        
var t = this.tf.getValue();
        
if(t && !(t instanceof Date)) {
            t 
= Date.parseDate(t, this.tf.format);
        }

        
if(t && !this.df.getValue()) {
            
this.initDateValue();
            
this.setDate(this.dateValue);
        }

        
if(this.dateValue instanceof Date) {
            
if(t) {
                
this.dateValue.setHours(t.getHours());
                
this.dateValue.setMinutes(t.getMinutes());
                
this.dateValue.setSeconds(t.getSeconds());
            }

            
else {
                
this.dateValue.setHours(0);
                
this.dateValue.setMinutes(0);
                
this.dateValue.setSeconds(0);
            }

        }

    }
 // eo function updateTime
    // }}}
    // {{{
    /**
     * private Updates the underlying hidden field value
     
*/

    ,updateHidden:
function() {
        
if(this.isRendered) {
            
var value = this.dateValue instanceof Date ? this.dateValue.format(this.hiddenFormat) : '';
            
this.el.dom.value = value;
        }

    }

    
// }}}
    // {{{
    /**
     * private Updates all of Date, Time and Hidden
     
*/

    ,updateValue:
function() {

        
this.updateDate();
        
this.updateTime();
        
this.updateHidden();

        
return;
    }
 // eo function updateValue
    // }}}
    // {{{
    /**
     * @return {Boolean} true = valid, false = invalid
     * callse validate methods of DateField and TimeField
     
*/

    ,validate:
function() {
        
return this.df.validate() && this.tf.validate();
    }
 // eo function validate
    // }}}
    // {{{
    /**
     * Returns renderer suitable to render this field
     * @param {Object} Column model config
     
*/

    ,renderer: 
function(field) {
        
        
var format = field.editor.dateFormat || Ext.ux.DateTime.prototype.dateFormat;
        format 
+= ' ' + (field.editor.timeFormat || Ext.ux.DateTime.prototype.timeFormat);
        
var renderer = function(val) {
            
var retval = Ext.util.Format.date(val, format);
            
return retval;
        }
;
        
return renderer;
    }
,
    markInvalid:
function(msg)
    
{
        
this.messages.push(msg);
         Ext.ux.DateTime.superclass.markInvalid.call(
this,msg);
    }
,
    clearInvalid:
function()
    
{
        
this.messages.pop();
        
if(this.messages.length==0)
        
{
             Ext.ux.DateTime.superclass.clearInvalid.call(
this);
        }

        
else
        
{
            
var msg=this.messages.pop();
            
this.markInvalid(msg);
        }

    }

    
    
    
// }}}

}
); // eo extend

// register xtype
Ext.reg('xdatetime', Ext.ux.DateTime);

使用例子
Ext.BLANK_IMAGE_URL = '../ext/resources/images/default/s.gif';
Ext.onReady(
function() {
    Ext.QuickTips.init();
    Ext.form.Field.prototype.msgTarget 
= 'side';
    
var win = new Ext.Window({
         width:
500
        ,id:'winid'
        ,height:
300
        ,layout:'fit'
        ,border:
false
        ,closable:
false
        ,title:'Ext.ux.DateTime Example'
        ,items:[
{
             xtype:'form'
            ,frame:
true
            ,labelWidth:
100
            ,id:'form'
            ,url:'.'
            ,items:[
{
                 xtype:'xdatetime'
                ,id:'dtf'
                ,fieldLabel:'Date 
& Time'
//                ,width:360
                ,anchor:'-18'
                ,timeFormat:'H:i:s'
                ,timeConfig: 
{
                     altFormats:'H:i:s'
                    ,allowBlank:
true    
                }

                ,dateFormat:'d.n.Y'
                ,dateConfig: 
{
                     altFormats:'Y
-m-d|Y-n-d'
                    ,allowBlank:
true    
                }

            }
]
        }
]
        ,buttons:[
{
             text:'Submit'
            ,handler:
function() {
                Ext.getCmp('form').getForm().submit();
            }

        }
]
    }
);
    win.show();
}
);




Let life be beautiful like summer flowers and death like autumn leaves.

posted on 2008-07-21 12:18 Alexwan 阅读(18299) 评论(31)  编辑  收藏 所属分类: JavaScript

评论

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2008-11-04 13:49 达到

我用了这个控件之后,在加载表单信息的时候,这个日期我始终无法正确从数据库中读取显示在页面上来!!请博主明示!时间很紧!
  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2008-11-04 18:41 Alexwan

这里有个比较关键地方:
服务端返回来的日期时间是以何种格式返回,例如java中的java.util.Date形式的,将使用下面的函数作为convert函数(可以在form的reader中设置):
function dateTimeConvertor(sTimestamp) {

if (typeof sTimestamp == "string")
{
sTimestamp = parseInt(sTimestamp);
}
else if(typeof sTimestamp=="object"&&sTimestamp&&sTimestamp.time)
{
sTimestamp=parseInt(sTimestamp.time);
}
if(sTimestamp)
{
var dtDate = new Date(sTimestamp);
return Ext.util.Format.date(dtDate,'Y-m-d H:i:s');
}
else return '';
}
  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本[未登录] 2008-11-13 15:37 wind

多谢,多谢  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2008-11-20 16:49 xiaoou22

经过学习,发现例子中不能调整日期控件的宽度,请博主解答一下,谢谢  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2008-11-20 18:10 Alexwan

可以分别使用timeWidth和dateWidth属性配置时间控件和日期控件的宽度

Ext.BLANK_IMAGE_URL = '../ext/resources/images/default/s.gif';
Ext.onReady(function() {
    Ext.QuickTips.init();
    Ext.form.Field.prototype.msgTarget = 'side';
    var win = new Ext.Window({
         width:500
        ,id:'winid'
        ,height:300
        ,layout:'fit'
        ,border:false
        ,closable:false
        ,title:'Ext.ux.DateTime Example'
        ,items:[{
             xtype:'form'
            ,frame:true
            ,labelWidth:100
            ,id:'form'
            ,url:'.'
            ,items:[{
                 xtype:'xdatetime'
                ,id:'dtf'
                ,fieldLabel:'Date & Time'
//                ,width:360
                ,anchor:'-18'
                ,timeWidth:80,
                ,timeFormat:'H:i:s'
                ,timeConfig: {
                     altFormats:'H:i:s'
                    ,allowBlank:true    
                }
                ,dateFormat:'d.n.Y'
                ,dateWidth:80,
                ,dateConfig: {
                     altFormats:'Y-m-d|Y-n-d'
                    ,allowBlank:true    
                }
            }]
        }]
        ,buttons:[{
             text:'Submit'
            ,handler:function() {
                Ext.getCmp('form').getForm().submit();
            }
        }]
    });
    win.show();
});
  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2008-11-21 08:17 xiaoou22

@Alexwan
精彩的控件,十分感谢,客户使用感觉良好。  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2008-11-27 17:39 budong

setValue()怎么用的老报错给个例子吧  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2008-11-28 08:55 Alexwan

楼上的是怎么用的?  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2008-12-02 09:36 xiaoou22

form.reset之后,只清空了
undefined-date
undefined-time
但还是没有清空组合的控件值。请赐教,谢谢哦。  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2008-12-02 10:28 Alexwan

呵呵,这算是一个BUG,需要修改一下reset方法,修改后的reset方法:

reset : function(){
this.df.reset();
this.tf.reset();
if(this.isRendered) {
this.el.dom.value = '';
}
this.clearInvalid();
}  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2009-02-03 14:55 yu

老大,applyTo怎么用啊,我applyto一个文本框报错啊  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2009-02-03 15:36 yu

解决了 在timeConfig和dateConfig里各加一个就ok了  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2009-02-04 13:37 杰╃PhoeNix

能不能说一说,这两控件的改良版本的优点在于什么地方?  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2009-02-04 18:31 Alexwan

改良后的优点主要体现在验证信息,是将两个组合起来的控件看作是一个控件,
验证信息也是针对这个控件而言  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2009-03-31 17:59 xx

楼主:请问为什么在选择2、4、6、9、11等月份时获取的值会自增1,也就是说命名选的是4月却获取到了5月,有没有相应的处理?
  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2009-04-01 09:04 Alexwan

楼上的确定是出现这样的现象还是误操作了?我及我的同事之前用的时候都从来没有碰到过这样的问题,认真检查一下看看吧  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2009-04-01 09:40 xx

谢谢楼主回答,不过问题真的存在,就是31天的月不会出问题,首次选别的月份的时候显示的是正确的,比如选4月,显示的是4月,但是form.find('name','nnn')[0].getValue()或form.find('name','nnn')[0].getRawValue()
得到的都是5月。但再选一次的话问题就没有了。就首次选存在问题。急用,麻烦楼主看下  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本[未登录] 2009-05-05 23:01 dd

楼主,还方便发个打包好的最新的空间代码,谢谢,好人做到底哦,:)sunbird8488@163.com  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本[未登录] 2009-06-25 20:16 Rain

请您给我一份
yuyezhouqiang@163.com  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本[未登录] 2009-06-25 20:17 Rain


由衷的感谢!!!  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2009-07-13 16:43 lingo

顶,能不能也给我一份呀,,lingo169@yahoo.com。先谢过  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本[未登录] 2009-07-24 23:58 Dream

很佩服楼主的实力!能否把最新源码发一份给我?急用啊!先谢了!我的邮箱:mjzdream@163.com ,谢谢!!!  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2009-12-07 12:56 xuezi_zh

楼主:使用您提供的《使用例子》后发现,首次录入日期后,当焦点进入时间框时,程序会自动输入当前时间。焦点离开时间框后时间值依然保留在框内,这是我们所希望的,没有问题。但是,如果使用下拉选项改变了时间值后,焦点离开时间框后,时间值就会从框中消失,这是我们不希望出现的。请问楼主该如何解决? 谢谢! 我的邮箱是:xuezi_zh@tom.com。  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2010-01-11 15:24 wxw404

你好 我正在找这样的空间 可以给我发一份吗?
wxw404@gmail.com
  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2010-01-14 10:22 sphinx

正在找像这样的日期时间控件!能否把最新源码发一份给我?先谢了!我的邮箱:yuanlijia1@163.com  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2010-08-30 13:40 jiajiafucs

为什么选中的值之后,还是原来的值,第二次才会出现选中的值呢?  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2010-09-17 14:32 langwang

斑竹,能不能也给我一份呀,太感谢了!
我的邮箱是: wangyi_xuxiaowei@163.com
谢谢!
我会继续的支持你的空间和你的文章!
谢谢  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2012-01-18 09:32 shusheng

版主,急求,希望能给我一份。谢谢! 76291534@qq.com  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2013-03-01 11:05 jjcao

版主能否给我一份源码,谢谢版主。503808858@qq.com  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2013-09-12 17:46 羽毛

lz大才,可以发源码给我好吗,急用,大谢,我的邮箱是weiaiyumao@163.com  回复  更多评论   

# re: [Extjs]基于Extjs2.0日期时间(DateTime)控件的改良版本 2013-11-11 12:03 wqe

时间控件只显示':'选择框没有,是什么问题?  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航: