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

📄 basicform.js

📁 Ext JS是一个创建丰富互联网应用程序的跨浏览器的JavaScrip库。它包含:高效率
💻 JS
📖 第 1 页 / 共 2 页
字号:
    },    success: function(form, action) {       Ext.Msg.alert("Success", action.result.msg);    },    failure: function(form, action) {        switch (action.failureType) {            case Ext.form.Action.CLIENT_INVALID:                Ext.Msg.alert("Failure", "Form fields may not be submitted with invalid values");                break;            case Ext.form.Action.CONNECT_FAILURE:                Ext.Msg.alert("Failure", "Ajax communication failed");                break;            case Ext.form.Action.SERVER_INVALID:               Ext.Msg.alert("Failure", action.result.msg);       }    }});</code></pre>     * would process the following server response for a successful submission:<pre><code>{    success: true,    msg: 'Consignment updated'}</code></pre>     * and the following server response for a failed submission:<pre><code>{    success: false,    msg: 'You do not have permission to perform this operation'}</code></pre>     * @return {BasicForm} this     */    submit : function(options){        if(this.standardSubmit){            var v = this.isValid();            if(v){                this.el.dom.submit();            }            return v;        }        this.doAction('submit', options);        return this;    },    /**     * Shortcut to {@link #doAction do} a {@link Ext.form.Action.Load load action}.     * @param {Object} options The options to pass to the action (see {@link #doAction} for details)     * @return {BasicForm} this     */    load : function(options){        this.doAction('load', options);        return this;    },    /**     * Persists the values in this form into the passed {@link 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 {@link Ext.data.Record} into this form by calling {@link #setValues} with the     * {@link Ext.data.Record#data record data}.     * See also {@link #trackResetOnLoad}.     * @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 {@link Ext.form.Field} in this form.     * @param {String} id The value to search for (specify either a {@link Ext.Component#id id},     * {@link Ext.grid.Column#dataIndex dataIndex}, {@link Ext.form.Field#getName name or hiddenName}).     * @return Field     */    findField : function(id){        var field = this.items.get(id);        if(!Ext.isObject(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(!Ext.isFunction(errors[id]) && (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(!Ext.isFunction(values[id]) && (field = this.findField(id))){                    field.setValue(values[id]);                    if(this.trackResetOnLoad){                        field.originalValue = field.getValue();                    }                }            }        }        return this;    },    /**     * <p>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.</p>     * <p><b>Note:</b> The values are collected from all enabled HTML input elements within the form, <u>not</u> from     * the Ext Field objects. This means that all returned values are Strings (or Arrays of Strings) and that the     * value can potentially be the emptyText of a field.</p>     * @param {Boolean} asString (optional) Pass true to return the values as a string. (defaults to false, returning an Object)     * @return {String/Object}     */    getValues : function(asString){        var fs = Ext.lib.Ajax.serializeForm(this.el.dom);        if(asString === true){            return fs;        }        return Ext.urlDecode(fs);    },    getFieldValues : function(){        var o = {};        this.items.each(function(f){           o[f.getName()] = f.getValue();        });        return o;    },    /**     * 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's Collection. This does not result in rendering of     * the passed Component, it just enables the form to validate Fields, and distribute values to     * Fields.     * <p><b>You will not usually call this function. In order to be rendered, a Field must be added     * to a {@link Ext.Container Container}, usually an {@link Ext.form.FormPanel FormPanel}.     * The FormPanel to which the field is added takes care of adding the Field to the BasicForm's     * collection.</b></p>     * @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;    },    /**     * Iterates through the {@link Ext.form.Field Field}s which have been {@link #add add}ed to this BasicForm,     * checks them for an id attribute, and calls {@link Ext.form.Field#applyToMarkup} 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;    },    callFieldMethod : function(fnName, args){        args = args || [];        this.items.each(function(f){            if(Ext.isFunction(f[fnName])){                f[fnName].apply(f, args);            }        });        return this;    }});// back compatExt.BasicForm = Ext.form.BasicForm;

⌨️ 快捷键说明

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