⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 basicform.js

📁 当前比较流行的,漂亮的JS框架,这里面用到的API文档
💻 JS
📖 第 1 页 / 共 2 页
字号:
    /**     * Persists the values in this form into the passed Ext.data.Record object in a beginEdit/endEdit block.     * @param {Record} record The record to edit     * @return {BasicForm} this     */    updateRecord : function(record){        record.beginEdit();        var fs = record.fields;        fs.each(function(f){            var field = this.findField(f.name);            if(field){                record.set(f.name, field.getValue());            }        }, this);        record.endEdit();        return this;    },    /**     * Loads an Ext.data.Record into this form.     * @param {Record} record The record to load     * @return {BasicForm} this     */    loadRecord : function(record){        this.setValues(record.data);        return this;    },    // private    beforeAction : function(action){        var o = action.options;        if(o.waitMsg){            if(this.waitMsgTarget === true){                this.el.mask(o.waitMsg, 'x-mask-loading');            }else if(this.waitMsgTarget){                this.waitMsgTarget = Ext.get(this.waitMsgTarget);                this.waitMsgTarget.mask(o.waitMsg, 'x-mask-loading');            }else{                Ext.MessageBox.wait(o.waitMsg, o.waitTitle || this.waitTitle || 'Please Wait...');            }        }    },    // private    afterAction : function(action, success){        this.activeAction = null;        var o = action.options;        if(o.waitMsg){            if(this.waitMsgTarget === true){                this.el.unmask();            }else if(this.waitMsgTarget){                this.waitMsgTarget.unmask();            }else{                Ext.MessageBox.updateProgress(1);                Ext.MessageBox.hide();            }        }        if(success){            if(o.reset){                this.reset();            }            Ext.callback(o.success, o.scope, [this, action]);            this.fireEvent('actioncomplete', this, action);        }else{            Ext.callback(o.failure, o.scope, [this, action]);            this.fireEvent('actionfailed', this, action);        }    },    /**     * Find a Ext.form.Field in this form by id, dataIndex, name or hiddenName.     * @param {String} id The value to search for     * @return Field     */    findField : function(id){        var field = this.items.get(id);        if(!field){            this.items.each(function(f){                if(f.isFormField && (f.dataIndex == id || f.id == id || f.getName() == id)){                    field = f;                    return false;                }            });        }        return field || null;    },    /**     * Mark fields in this form invalid in bulk.     * @param {Array/Object} errors Either an array in the form [{id:'fieldId', msg:'The message'},...] or an object hash of {id: msg, id2: msg2}     * @return {BasicForm} this     */    markInvalid : function(errors){        if(Ext.isArray(errors)){            for(var i = 0, len = errors.length; i < len; i++){                var fieldError = errors[i];                var f = this.findField(fieldError.id);                if(f){                    f.markInvalid(fieldError.msg);                }            }        }else{            var field, id;            for(id in errors){                if(typeof errors[id] != 'function' && (field = this.findField(id))){                    field.markInvalid(errors[id]);                }            }        }        return this;    },    /**     * Set values for fields in this form in bulk.     * @param {Array/Object} values Either an array in the form:<br><br><code><pre>[{id:'clientName', value:'Fred. Olsen Lines'}, {id:'portOfLoading', value:'FXT'}, {id:'portOfDischarge', value:'OSL'} ]</pre></code><br><br>     * or an object hash of the form:<br><br><code><pre>{    clientName: 'Fred. Olsen Lines',    portOfLoading: 'FXT',    portOfDischarge: 'OSL'}</pre></code><br>     * @return {BasicForm} this     */    setValues : function(values){        if(Ext.isArray(values)){ // array of objects            for(var i = 0, len = values.length; i < len; i++){                var v = values[i];                var f = this.findField(v.id);                if(f){                    f.setValue(v.value);                    if(this.trackResetOnLoad){                        f.originalValue = f.getValue();                    }                }            }        }else{ // object hash            var field, id;            for(id in values){                if(typeof values[id] != 'function' && (field = this.findField(id))){                    field.setValue(values[id]);                    if(this.trackResetOnLoad){                        field.originalValue = field.getValue();                    }                }            }        }        return this;    },    /**     * Returns the fields in this form as an object with key/value pairs as they would be submitted using a standard form submit.     * If multiple fields exist with the same name they are returned as an array.     * @param {Boolean} asString (optional) false to return the the values as an object (defaults to returning as a string)     * @return {String/Object}     */    getValues : function(asString){        var fs = Ext.lib.Ajax.serializeForm(this.el.dom);        if(asString === true){            return fs;        }        return Ext.urlDecode(fs);    },    /**     * Clears all invalid messages in this form.     * @return {BasicForm} this     */    clearInvalid : function(){        this.items.each(function(f){           f.clearInvalid();        });        return this;    },    /**     * Resets this form.     * @return {BasicForm} this     */    reset : function(){        this.items.each(function(f){            f.reset();        });        return this;    },    /**     * Add Ext.form components to this form.     * @param {Field} field1     * @param {Field} field2 (optional)     * @param {Field} etc (optional)     * @return {BasicForm} this     */    add : function(){        this.items.addAll(Array.prototype.slice.call(arguments, 0));        return this;    },    /**     * Removes a field from the items collection (does NOT remove its markup).     * @param {Field} field     * @return {BasicForm} this     */    remove : function(field){        this.items.remove(field);        return this;    },    /**     * Looks at the fields in this form, checks them for an id attribute,     * and calls applyTo on the existing dom element with that id.     * @return {BasicForm} this     */    render : function(){        this.items.each(function(f){            if(f.isFormField && !f.rendered && document.getElementById(f.id)){ // if the element exists                f.applyToMarkup(f.id);            }        });        return this;    },    /**     * Calls {@link Ext#apply} for all fields in this form with the passed object.     * @param {Object} values     * @return {BasicForm} this     */    applyToFields : function(o){        this.items.each(function(f){           Ext.apply(f, o);        });        return this;    },    /**     * Calls {@link Ext#applyIf} for all field in this form with the passed object.     * @param {Object} values     * @return {BasicForm} this     */    applyIfToFields : function(o){        this.items.each(function(f){           Ext.applyIf(f, o);        });        return this;    }});// back compatExt.BasicForm = Ext.form.BasicForm;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -