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

📄 history.js

📁 SugarCRM5.1 开源PHP客户关系管理系统
💻 JS
📖 第 1 页 / 共 2 页
字号:
          // Ext.ux.History.navigate has been called or after          // the user has hit the back/forward button.          // On Safari 1.x and 2.0, the only way to catch a back/forward          // operation is to watch history.length... We basically exploit          // what I consider to be a bug (history.length is not supposed          // to change when going back/forward in the history...) This is          // why, in the following thread, we first compare the hash,          // because the hash thing will be fixed in the next major          // version of Safari. So even if they fix the history.length          // bug, all this will still work!          counter = history.length;          // On Gecko and Opera, we just need to watch the hash...          hash = _getHash();          setInterval( function () {              var state;              var newHash;              var newCounter;              newHash = _getHash();              newCounter = history.length;              if ( newHash !== hash ) {                  hash = newHash;                  counter = newCounter;                  _handleFQStateChange( hash );                  _storeStates();              } else if ( newCounter !== counter ) {                  // If we ever get here, we should be on Safari...                  hash = newHash;                  counter = newCounter;                  state = _fqstates[counter - 1];                  _handleFQStateChange( state );                  _storeStates();              }          }, 50 );          _initialized = true;      }          }    return Ext.apply(new Ext.util.Observable (), {				isReady: function(){			return _initialized;		},		/**         * Registers a new module.         *         * @method register         * @param {string} module Non-empty string uniquely identifying the         *     module you wish to register.         * @param {string} initialState The initial state of the specified         *     module corresponding to its earliest history entry.         * @param {function} onStateChange Callback called when the         *     state of the specified module has changed.         * @param {object} obj An arbitrary object that will be passed as a         *     parameter to the handler.         * @param {boolean} override If true, the obj passed in becomes the         *     execution scope of the listener.         */        register: function ( module, initialState, onStateChange, obj, override ) {            var scope;            var wrappedFn;            if ( typeof module !== "string" || _trim( module ) === "" ||                 typeof initialState !== "string" ||                 typeof onStateChange !== "function" ) {                throw new Error( "Missing or invalid argument passed to Ext.ux.History.register" );            }            if ( _modules[module] ) {                // Here, we used to throw an exception. However, users have                // complained about this behavior, so we now just return.                return;            }            // Note: A module CANNOT be registered after calling            // Ext.ux.History.initialize. Indeed, we set the initial state            // of each registered module in Ext.ux.History.initialize.            // If you could register a module after initializing the Browser            // History Manager, you would not read the correct state using            // Ext.ux.History.getCurrentState when coming back to the            // page using the back button.            if ( _initialized ) {                throw new Error( "All modules must be registered before calling Ext.ux.History.initialize" );            }            // Make sure the strings passed in do not contain our separators "," and "|"            module = escape( module );            initialState = escape( initialState );            // If the user chooses to override the scope, we use the            // custom object passed in as the execution scope.            scope = null;            if ( override === true ) {                scope = obj;            } else {                scope = override;            }            wrappedFn = function ( state ) {                return onStateChange.call( scope, state, obj );            };            _modules[module] = {                name: module,                initialState: initialState,                currentState: initialState,                onStateChange: wrappedFn            };        },        /**         * Initializes the Browser History Manager. Call this method         * from a script block located right after the opening body tag.         *         * @method initialize         * @param {string|HTML Element} stateField <input type="hidden"> used         *     to store application states. Must be in the static markup.         * @param {string|HTML Element} histFrame IFrame used to store         *     the history (only required on Internet Explorer)         * @public         */         initialize: function (stateField, histFrame) {            if (_initialized) {                // The browser history manager has already been initialized.                return;            }            if (typeof stateField === "string") {                stateField = document.getElementById(stateField);            }            if (!stateField ||                stateField.tagName !== "TEXTAREA" &&                (stateField.tagName !== "INPUT" ||                 stateField.type !== "hidden" &&                 stateField.type !== "text")) {                stateField =  Ext.DomHelper.append(document.body, 					{tag: 'input', id: 'yui_hist_field', type: 'hidden' }, false);            }            _storageField = stateField;            if (Ext.isIE) {				if (typeof histFrame === "string") {                    histFrame = document.getElementById(histFrame);                }                if (!histFrame || histFrame.tagName !== "IFRAME") {					Ext.DomHelper.append(document.body, {						tag: 'iframe',						id: 'yui_hist_iframe',						src: 'javascript:document.open();document.write(&quot;' + new Date().getTime() + '&quot;);document.close();',						style: 'position:absolute;display:none;'					});				}                 _iFrame = histFrame;            }            Ext.onReady(_initialize);            _initialized = true;        },        /**         * Call this method when you want to store a new entry in the browser's history.         *         * @method navigate         * @param {string} module Non-empty string representing your module.         * @param {string} state String representing the new state of the specified module.         * @return {boolean} Indicates whether the new state was successfully added to the history.         * @public         */        navigate: function ( module, state ) {            var states;            if ( typeof module !== "string" || typeof state !== "string" ) {                throw new Error( "Missing or invalid argument passed to Ext.ux.History.navigate" );            }            states = {};            states[module] = state;            return Ext.ux.History.multiNavigate( states );        },        /**         * Call this method when you want to store a new entry in the browser's history.         *         * @method multiNavigate         * @param {object} states Associative array of module-state pairs to set simultaneously.         * @return {boolean} Indicates whether the new state was successfully added to the history.         * @public         */        multiNavigate: function ( states ) {            var currentStates;            var moduleName;            var moduleObj;            var currentState;            var fqstate;            var html;            var doc;            if ( typeof states !== "object" ) {                throw new Error( "Missing or invalid argument passed to Ext.ux.History.multiNavigate" );            }            if ( !_initialized ) {                throw new Error( "The Browser History Manager is not initialized" );            }            for ( moduleName in states ) {                if ( !_modules[moduleName] ) {                    throw new Error( "The following module has not been registered: " + moduleName );                }            }            // Generate our new full state string mod1=xxx&mod2=yyy            currentStates = [];            for ( moduleName in _modules ) {                if ( _modules.hasOwnProperty(moduleName ) ) {                    moduleObj = _modules[moduleName];                    if ( _modules.hasOwnProperty(moduleName ) ) {                        currentState = states[moduleName];                    } else {                        currentState = moduleObj.currentState;                    }                    // Make sure the strings passed in do not contain our separators "," and "|"                    moduleName = escape( moduleName );                    currentState = escape( currentState );                    currentStates.push( moduleName + "=" + currentState );                }            }            fqstate = currentStates.join( "&" );            if ( Ext.isIE ) {                return _updateIFrame(fqstate);            } else {                // Known bug: On Safari 1.x and 2.0, if you have tab browsing                // enabled, Safari will show an endless loading icon in the                // tab. This has apparently been fixed in recent WebKit builds.                // One work around found by Dav Glass is to submit a form that                // points to the same document. This indeed works on Safari 1.x                // and 2.0 but creates bigger problems on WebKit. So for now,                // we'll consider this an acceptable bug, and hope that Apple                // comes out with their next version of Safari very soon.                top.location.hash = fqstate;                if ( Ext.isSafari ) {                    // The following two lines are only useful for Safari 1.x                    // and 2.0. Recent nightly builds of WebKit do not require                    // that, but unfortunately, it is not easy to differentiate                    // between the two. Once Safari 2.0 departs the A-grade                    // list, we can remove the following two lines...                    _fqstates[history.length] = fqstate;                    _storeStates();                }            }            return true;        },        /**         * Returns the current state of the specified module.         *         * @method getCurrentState         * @param {string} module Non-empty string representing your module.         * @return {string} The current state of the specified module.         * @public         */        getCurrentState: function ( module ) {            var moduleObj;            if ( typeof module !== "string" ) {                throw new Error( "Missing or invalid argument passed to Ext.ux.History.getCurrentState" );            }            if ( !_storageFieldReady ) {                throw new Error( "The Browser History Manager is not initialized" );            }            moduleObj = _modules[module];            if ( !moduleObj ) {                throw new Error( "No such registered module: " + module );            }            return unescape( moduleObj.currentState );        },        /**         * Returns the state of a module according to the URL fragment         * identifier. This method is useful to initialize your modules         * if your application was bookmarked from a particular state.         *         * @method getBookmarkedState         * @param {string} module Non-empty string representing your module.         * @return {string} The bookmarked state of the specified module.         * @public         */        getBookmarkedState: function ( module ) {            var i;            var len;            var hash;            var states;            var tokens;            var moduleName;            if ( typeof module !== "string" ) {                throw new Error( "Missing or invalid argument passed to Ext.ux.History.getBookmarkedState" );            }            // Use location.href instead of location.hash which is already            // URL-decoded, which creates problems if the state value            // contained special characters...            idx = top.location.href.indexOf("#");            hash = idx >= 0 ? top.location.href.substr(idx + 1) : top.location.href;            states = hash.split("&");            for (i = 0, len = states.length; i < len; i++) {                tokens = states[i].split("=");                if (tokens.length === 2) {                    moduleName = tokens[0];                    if (moduleName === module) {                        return unescape(tokens[1]);                    }                }            }            return null;        },        /**         * Returns the value of the specified query string parameter.         * This method is not used internally by the Browser History Manager.         * However, it is provided here as a helper since many applications         * using the Browser History Manager will want to read the value of         * url parameters to initialize themselves.         *         * @method getQueryStringParameter         * @param {string} paramName Name of the parameter we want to look up.         * @param {string} queryString Optional URL to look at. If not specified,         *     this method uses the URL in the address bar.         * @return {string} The value of the specified parameter, or null.         * @public         */        getQueryStringParameter: function ( paramName, url ) {            var i;            var len;            var idx;            var queryString;            var params;            var tokens;            url = url || top.location.href;            idx = url.indexOf("?");            queryString = idx >= 0 ? url.substr(idx + 1) : url;            // Remove the hash if any            idx = queryString.lastIndexOf("#");            queryString = idx >= 0 ? queryString.substr(0, idx) : queryString;            params = queryString.split("&");            for (i = 0, len = params.length; i < len; i++) {                tokens = params[i].split("=");                if (tokens.length >= 2) {                    if (tokens[0] === paramName) {                        return unescape(tokens[1]);                    }                }            }            return null;        }    });}();

⌨️ 快捷键说明

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