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

📄 cookieclass.js

📁 一个真正的CMS系统,可以完全实现建站自动化,用.NET开发.
💻 JS
字号:
// This code is taken from O'Reilly's "JavaScript: The Definitive Guide"
// 4th Edition, Example 16-1 on pages 270-273.  Slightly modified.
//
// John Methot
// 3/6/2003

// The constructor function: creates a cookie object for the specified
// document, with a specified name and optional attributes.
// Arguments:
//   document: The Document object that the cookie is stored for. Required.
//   name:     A string that specifies a name for the cookie. Required.
//   hours:    An optional number that specifies the number of hours from now
//             that the cookie should expire.
//   path:     An optional string that specifies the cookie path attribute.
//   domain:   An optional string that specifies the cookie domain attribute.
//   secure:   An optional Boolean value that, if true, requests a secure cookie.
//
function Cookie(document, name, hours, path, domain, secure)
{
    // All the predefined properties of this object begin with '$'
    // to distinguish them from other properties which are the values to
    // be stored in the cookie.
    this.$document = document;
    this.$name = name;
    if (hours)
        this.$expiration = new Date((new Date()).getTime() + hours*3600000.0);
    else this.$expiration = null;
    if (path) this.$path = path; else this.$path = null;
    if (domain) this.$domain = domain; else this.$domain = null;
    if (secure) this.$secure = true; else this.$secure = false;
}

// This function is the store() method of the Cookie object.
Cookie.prototype.store = function () {
    // First, loop through the properties of the Cookie object and
    // put together the value of the cookie. Since cookies use the
    // equals sign and semicolons as separators, we'll use colons
    // and ampersands for the individual state variables we store 
    // within a single cookie value. Note that we escape the value
    // of each state variable, in case it contains punctuation or other
    // illegal characters.
    var cookieval = "";
    for(var prop in this) {
        // Ignore properties with names that begin with '$' and also methods.
        if ((prop.charAt(0) == '$') || ((typeof this[prop]) == 'function')) 
            continue;
        if (cookieval != "") cookieval += '&';
        cookieval += prop + ':' + escape(this[prop]);
    }

    // Now that we have the value of the cookie, put together the 
    // complete cookie string, which includes the name and the various
    // attributes specified when the Cookie object was created.
    var cookie = this.$name + '=' + cookieval;
    if (this.$expiration)
        cookie += '; expires=' + this.$expiration.toGMTString();
    if (this.$path) cookie += '; path=' + this.$path;
    if (this.$domain) cookie += '; domain=' + this.$domain;
    if (this.$secure) cookie += '; secure';

    // Now store the cookie by setting the magic Document.cookie property.
    this.$document.cookie = cookie;
}

// This function is the load() method of the Cookie object.
Cookie.prototype.load = function() { 
    // First, get a list of all cookies that pertain to this document.
    // We do this by reading the magic Document.cookie property.
    var allcookies = this.$document.cookie;
    if (allcookies == "") return false;

    // Now extract just the named cookie from that list.
    var start = allcookies.indexOf(this.$name + '=');
    if (start == -1) return false;   // Cookie not defined for this page.
    start += this.$name.length + 1;  // Skip name and equals sign.
    var end = allcookies.indexOf(';', start);
    if (end == -1) end = allcookies.length;
    var cookieval = allcookies.substring(start, end);

    // Now that we've extracted the value of the named cookie, we've
    // got to break that value down into individual state variable 
    // names and values. The name/value pairs are separated from each
    // other by ampersands, and the individual names and values are
    // separated from each other by colons. We use the split method
    // to parse everything.
    var a = cookieval.split('&');    // Break it into array of name/value pairs.
    for(var i=0; i < a.length; i++)  // Break each pair into an array.
        a[i] = a[i].split(':');

    // Now that we've parsed the cookie value, set all the names and values
    // of the state variables in this Cookie object. Note that we unescape()
    // the property value, because we called escape() when we stored it.
    for(var i = 0; i < a.length; i++) {
        this[a[i][0]] = unescape(a[i][1]);
    }

    // We're done, so return the success code.
    return true;
}

// This function is the remove() method of the Cookie object.
Cookie.prototype.remove = function() {
    var cookie;
    cookie = this.$name + '=';
    if (this.$path) cookie += '; path=' + this.$path;
    if (this.$domain) cookie += '; domain=' + this.$domain;
    cookie += '; expires=Fri, 02-Jan-1970 00:00:00 GMT';

    this.$document.cookie = cookie;
}

//
// utility methods that use the Cookie class to store arbitrary
// "properties" as wlw.help.<property-name> cookies.
//
function getCookie(propName)
{
  var cookie = new Cookie(document, "wlw.help." + propName);
  var retval = null;
  if (cookie.load())
  {
    retval = cookie.value;
  }
  debug("getCookie(" + propName + ") = " + retval);
  return retval;
}

//
// utility methods that use the Cookie class to store arbitrary
// "properties" as wlw.help.<property-name> cookies.
//
function setCookie(propName, value)
{
  debug("setCookie(" + propName + ", " + value + ")");
  var cookie = new Cookie(document, "wlw.help." + propName, 1, "/");
  cookie.value = value;
  cookie.store();
} 

///////////////////////////////////////////////////////////////////////////////
//
// Utilities supporting the Extensible Help system.
//
///////////////////////////////////////////////////////////////////////////////

///////////////////////////////////////////////////////////////////////////////
//
// _console and debug() provide a simple debug output system. debug()
// pops up a plain text window and directs output to it.
//
var _console = null;

function debugDisplay(msg)
{
  if((_console == null) || (_console.closed))
  {
    _console = window.open("", "console", "width=600,height=300,resizable,scrollbars");
    _console.document.open("text/plain");
  }
  _console.focus();
  _console.document.writeln(msg);
}

function debug(msg)
{
//  debugDisplay(msg);
}

// we want to append a ?query to the url if
// it isn't already there. If the URL has a #fragment,
// the #fragment has to come after the ?query, so grab
// the #fragment, append the ?query to the base URL,
// then append the #fragment back to the very end
function appendQuery(url, query)
{
  var retval = url;
  var fragment = null;
  var index;
  var newURL;

  if( url.indexOf(query) < 0 )
  {
    if( (index = url.indexOf("#")) > 0 )
    {
      fragment = url.substring(index);
      newURL = url.substring(0,index)
      newURL += query;
      newURL += fragment;
      retval = newURL;
    }

    // if there is no #fragment, just append the ?query
    else
    {
      retval = url + query;
    }
  }
  return retval;
}

⌨️ 快捷键说明

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