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

📄 window.js

📁 当前比较流行的,漂亮的JS框架,这里面用到的API文档
💻 JS
📖 第 1 页 / 共 2 页
字号:
/*
 * Ext JS Library 2.0.2
 * Copyright(c) 2006-2008, Ext JS, LLC.
 * licensing@extjs.com
 * 
 * http://extjs.com/license
 */

/** * @class Ext.Window * @extends Ext.Panel * A specialized panel intended for use as an application window.  Windows are floated and draggable by default, and * also provide specific behavior like the ability to maximize and restore (with an event for minimizing, since the * minimize behavior is application-specific).  Windows can also be linked to a {@link Ext.WindowGroup} or managed * by the {@link Ext.WindowManager} to provide grouping, activation, to front/back and other application-specific behavior. * @constructor * @param {Object} config The config object */Ext.Window = Ext.extend(Ext.Panel, {    /**     * @cfg {Boolean} modal     * True to make the window modal and mask everything behind it when displayed, false to display it without     * restricting access to other UI elements (defaults to false).     */    /**     * @cfg {String/Element} animateTarget     * Id or element from which the window should animate while opening (defaults to null with no animation).     */    /**     * @cfg {String} resizeHandles     * A valid {@link Ext.Resizable} handles config string (defaults to 'all').  Only applies when resizable = true.     */    /**     * @cfg {Ext.WindowGroup} manager     * A reference to the WindowGroup that should manage this window (defaults to {@link Ext.WindowMgr}).     */    /**    * @cfg {String/Number/Button} defaultButton    * The id / index of a button or a button instance to focus when this window received the focus.    */    /**    * @cfg {Function} onEsc    * Allows override of the built-in processing for the escape key. Default action    * is to close the Window (performing whatever action is specified in {@link #closeAction}.    * To prevent the Window closing when the escape key is pressed, specify this as     * Ext.emptyFn (See {@link Ext#emptyFn}).    */    /**    * @cfg {String} baseCls    * The base CSS class to apply to this panel's element (defaults to 'x-window').    */    baseCls : 'x-window',    /**     * @cfg {Boolean} resizable     * True to allow user resizing at each edge and corner of the window, false to disable resizing (defaults to true).     */    resizable:true,    /**     * @cfg {Boolean} draggable     * True to allow the window to be dragged by the header bar, false to disable dragging (defaults to true).  Note     * that by default the window will be centered in the viewport, so if dragging is disabled the window may need     * to be positioned programmatically after render (e.g., myWindow.setPosition(100, 100);).     */    draggable:true,    /**     * @cfg {Boolean} closable     * True to display the 'close' tool button and allow the user to close the window, false to hide the button and     * disallow closing the window (default to true).     */    closable : true,    /**     * @cfg {Boolean} constrain     * True to constrain the window to the viewport, false to allow it to fall outside of the viewport     * (defaults to false).  Optionally the header only can be constrained using {@link #constrainHeader}.     */    constrain:false,    /**     * @cfg {Boolean} constrainHeader     * True to constrain the window header to the viewport, allowing the window body to fall outside of the viewport,     * false to allow the header to fall outside the viewport (defaults to false).  Optionally the entire window     * can be constrained using {@link #constrain}.     */    constrainHeader:false,    /**     * @cfg {Boolean} plain     * True to render the window body with a transparent background so that it will blend into the framing     * elements, false to add a lighter background color to visually highlight the body element and separate it     * more distinctly from the surrounding frame (defaults to false).     */    plain:false,    /**     * @cfg {Boolean} minimizable     * True to display the 'minimize' tool button and allow the user to minimize the window, false to hide the button     * and disallow minimizing the window (defaults to false).  Note that this button provides no implementation --     * the behavior of minimizing a window is implementation-specific, so the minimize event must be handled and a     * custom minimize behavior implemented for this option to be useful.     */    minimizable : false,    /**     * @cfg {Boolean} maximizable     * True to display the 'maximize' tool button and allow the user to maximize the window, false to hide the button     * and disallow maximizing the window (defaults to false).  Note that when a window is maximized, the tool button     * will automatically change to a 'restore' button with the appropriate behavior already built-in that will     * restore the window to its previous size.     */    maximizable : false,    /**     * @cfg {Number} minHeight     * The minimum height in pixels allowed for this window (defaults to 100).  Only applies when resizable = true.     */    minHeight: 100,    /**     * @cfg {Number} minWidth     * The minimum width in pixels allowed for this window (defaults to 200).  Only applies when resizable = true.     */    minWidth: 200,    /**     * @cfg {Boolean} expandOnShow     * True to always expand the window when it is displayed, false to keep it in its current state (which may be     * collapsed) when displayed (defaults to true).     */    expandOnShow: true,    /**     * @cfg {String} closeAction     * The action to take when the close button is clicked.  The default action is 'close' which will actually remove     * the window from the DOM and destroy it.  The other valid option is 'hide' which will simply hide the window     * by setting visibility to hidden and applying negative offsets, keeping the window available to be redisplayed     * via the {@link #show} method.     */    closeAction: 'close',    // inherited docs, same default    collapsible:false,    // private    initHidden : true,    /**    * @cfg {Boolean} monitorResize @hide    * This is automatically managed based on the value of constrain and constrainToHeader    */    monitorResize : true,    // The following configs are set to provide the basic functionality of a window.    // Changing them would require additional code to handle correctly and should    // usually only be done in subclasses that can provide custom behavior.  Changing them    // may have unexpected or undesirable results.    /** @cfg {String} elements @hide */    elements: 'header,body',    /** @cfg {Boolean} frame @hide */    frame:true,    /** @cfg {Boolean} floating @hide */    floating:true,    // private    initComponent : function(){        Ext.Window.superclass.initComponent.call(this);        this.addEvents(            /**             * @event activate             * Fires after the window has been visually activated via {@link setActive}.             * @param {Ext.Window} this             */            /**             * @event deactivate             * Fires after the window has been visually deactivated via {@link setActive}.             * @param {Ext.Window} this             */            /**             * @event resize             * Fires after the window has been resized.             * @param {Ext.Window} this             * @param {Number} width The window's new width             * @param {Number} height The window's new height             */            'resize',            /**             * @event maximize             * Fires after the window has been maximized.             * @param {Ext.Window} this             */            'maximize',            /**             * @event minimize             * Fires after the window has been minimized.             * @param {Ext.Window} this             */            'minimize',            /**             * @event restore             * Fires after the window has been restored to its original size after being maximized.             * @param {Ext.Window} this             */            'restore'        );    },    // private    getState : function(){        return Ext.apply(Ext.Window.superclass.getState.call(this) || {}, this.getBox());    },    // private    onRender : function(ct, position){        Ext.Window.superclass.onRender.call(this, ct, position);        if(this.plain){            this.el.addClass('x-window-plain');        }        // this element allows the Window to be focused for keyboard events        this.focusEl = this.el.createChild({                    tag: "a", href:"#", cls:"x-dlg-focus",                    tabIndex:"-1", html: " "});        this.focusEl.swallowEvent('click', true);        this.proxy = this.el.createProxy("x-window-proxy");        this.proxy.enableDisplayMode('block');        if(this.modal){            this.mask = this.container.createChild({cls:"ext-el-mask"}, this.el.dom);            this.mask.enableDisplayMode("block");            this.mask.hide();        }    },    // private    initEvents : function(){        Ext.Window.superclass.initEvents.call(this);        if(this.animateTarget){            this.setAnimateTarget(this.animateTarget);        }        if(this.resizable){            this.resizer = new Ext.Resizable(this.el, {                minWidth: this.minWidth,                minHeight:this.minHeight,                handles: this.resizeHandles || "all",                pinned: true,                resizeElement : this.resizerAction            });            this.resizer.window = this;            this.resizer.on("beforeresize", this.beforeResize, this);        }        if(this.draggable){            this.header.addClass("x-window-draggable");        }        this.initTools();        this.el.on("mousedown", this.toFront, this);        this.manager = this.manager || Ext.WindowMgr;        this.manager.register(this);        this.hidden = true;        if(this.maximized){            this.maximized = false;            this.maximize();        }        if(this.closable){            var km = this.getKeyMap();            km.on(27, this.onEsc, this);            km.disable();        }    },    initDraggable : function(){        this.dd = new Ext.Window.DD(this);      },   // private    onEsc : function(){        this[this.closeAction]();      },    // private    beforeDestroy : function(){        Ext.destroy(            this.resizer,            this.dd,            this.proxy,            this.mask        );        Ext.Window.superclass.beforeDestroy.call(this);    },        // private    onDestroy : function(){        if(this.manager){            this.manager.unregister(this);        }        Ext.Window.superclass.onDestroy.call(this);    },    // private    initTools : function(){        if(this.minimizable){            this.addTool({                id: 'minimize',                handler: this.minimize.createDelegate(this, [])            });        }        if(this.maximizable){            this.addTool({                id: 'maximize',                handler: this.maximize.createDelegate(this, [])            });            this.addTool({                id: 'restore',                handler: this.restore.createDelegate(this, []),                hidden:true            });            this.header.on('dblclick', this.toggleMaximize, this);        }        if(this.closable){            this.addTool({                id: 'close',                handler: this[this.closeAction].createDelegate(this, [])            });        }    },    // private    resizerAction : function(){        var box = this.proxy.getBox();        this.proxy.hide();        this.window.handleResize(box);        return box;    },    // private    beforeResize : function(){        this.resizer.minHeight = Math.max(this.minHeight, this.getFrameHeight() + 40); // 40 is a magic minimum content size?        this.resizer.minWidth = Math.max(this.minWidth, this.getFrameWidth() + 40);        this.resizeBox = this.el.getBox();    },    // private    updateHandles : function(){        if(Ext.isIE && this.resizer){            this.resizer.syncHandleHeight();            this.el.repaint();        }    },    // private    handleResize : function(box){        var rz = this.resizeBox;        if(rz.x != box.x || rz.y != box.y){            this.updateBox(box);        }else{            this.setSize(box);        }        this.focus();        this.updateHandles();        this.saveState();        this.fireEvent("resize", this, box.width, box.height);    },    /**     * Focuses the window.  If a defaultButton is set, it will receive focus, otherwise the     * window itself will receive focus.     */    focus : function(){        var f = this.focusEl, db = this.defaultButton, t = typeof db;        if(t != 'undefined'){            if(t == 'number'){                f = this.buttons[db];            }else if(t == 'string'){                f = Ext.getCmp(db);            }else{                f = db;            }        }        f.focus.defer(10, f);    },    /**     * Sets the target element from which the window should animate while opening.     * @param {String/Element} el The target element or id     */    setAnimateTarget : function(el){        el = Ext.get(el);        this.animateTarget = el;    },    // private    beforeShow : function(){        delete this.el.lastXY;        delete this.el.lastLT;        if(this.x === undefined || this.y === undefined){            var xy = this.el.getAlignToXY(this.container, 'c-c');            var pos = this.el.translatePoints(xy[0], xy[1]);            this.x = this.x === undefined? pos.left : this.x;            this.y = this.y === undefined? pos.top : this.y;        }        this.el.setLeftTop(this.x, this.y);        if(this.expandOnShow){            this.expand(false);        }        if(this.modal){            Ext.getBody().addClass("x-body-masked");            this.mask.setSize(Ext.lib.Dom.getViewWidth(true), Ext.lib.Dom.getViewHeight(true));            this.mask.show();        }    },    /**     * Shows the window, rendering it first if necessary, or activates it and brings it to front if hidden.     * @param {String/Element} animateTarget (optional) The target element or id from which the window should     * animate while opening (defaults to null with no animation)     * @param {Function} callback (optional) A callback function to call after the window is displayed     * @param {Object} scope (optional) The scope in which to execute the callback     */    show : function(animateTarget, cb, scope){        if(!this.rendered){            this.render(Ext.getBody());        }        if(this.hidden === false){

⌨️ 快捷键说明

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