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

📄 prototype.js

📁 一百多个例子很好的verilog 学习资料
💻 JS
📖 第 1 页 / 共 3 页
字号:
Ajax.Responders.register({  onCreate: function() {    Ajax.activeRequestCount++;  },  onComplete: function() {    Ajax.activeRequestCount--;  }});Ajax.Base = function() {};Ajax.Base.prototype = {  setOptions: function(options) {    this.options = {      method:       'post',      asynchronous: true,      parameters:   ''    }    Object.extend(this.options, options || {});  },  responseIsSuccess: function() {    return this.transport.status == undefined        || this.transport.status == 0        || (this.transport.status >= 200 && this.transport.status < 300);  },  responseIsFailure: function() {    return !this.responseIsSuccess();  }}Ajax.Request = Class.create();Ajax.Request.Events =  ['Uninitialized', 'Loading', 'Loaded', 'Interactive', 'Complete'];Ajax.Request.prototype = Object.extend(new Ajax.Base(), {  initialize: function(url, options) {    this.transport = Ajax.getTransport();    this.setOptions(options);    this.request(url);  },  request: function(url) {    var parameters = this.options.parameters || '';    if (parameters.length > 0) parameters += '&_=';    try {      this.url = url;      if (this.options.method == 'get' && parameters.length > 0)        this.url += (this.url.match(/\?/) ? '&' : '?') + parameters;      Ajax.Responders.dispatch('onCreate', this, this.transport);      this.transport.open(this.options.method, this.url,        this.options.asynchronous);      if (this.options.asynchronous) {        this.transport.onreadystatechange = this.onStateChange.bind(this);        setTimeout((function() {this.respondToReadyState(1)}).bind(this), 10);      }      this.setRequestHeaders();      var body = this.options.postBody ? this.options.postBody : parameters;      this.transport.send(this.options.method == 'post' ? body : null);    } catch (e) {      this.dispatchException(e);    }  },  setRequestHeaders: function() {    var requestHeaders =      ['X-Requested-With', 'XMLHttpRequest',       'X-Prototype-Version', Prototype.Version];    if (this.options.method == 'post') {      requestHeaders.push('Content-type',        'application/x-www-form-urlencoded');      if (this.transport.overrideMimeType)        requestHeaders.push('Connection', 'close');    }    if (this.options.requestHeaders)      requestHeaders.push.apply(requestHeaders, this.options.requestHeaders);    for (var i = 0; i < requestHeaders.length; i += 2)      this.transport.setRequestHeader(requestHeaders[i], requestHeaders[i+1]);  },  onStateChange: function() {    var readyState = this.transport.readyState;    if (readyState != 1)      this.respondToReadyState(this.transport.readyState);  },  header: function(name) {    try {      return this.transport.getResponseHeader(name);    } catch (e) {}  },  evalJSON: function() {    try {      return eval(this.header('X-JSON'));    } catch (e) {}  },  evalResponse: function() {    try {      return eval(this.transport.responseText);    } catch (e) {      this.dispatchException(e);    }  },  respondToReadyState: function(readyState) {    var event = Ajax.Request.Events[readyState];    var transport = this.transport, json = this.evalJSON();    if (event == 'Complete') {      try {        (this.options['on' + this.transport.status]         || this.options['on' + (this.responseIsSuccess() ? 'Success' : 'Failure')]         || Prototype.emptyFunction)(transport, json);      } catch (e) {        this.dispatchException(e);      }      if ((this.header('Content-type') || '').match(/^text\/javascript/i))        this.evalResponse();    }    try {      (this.options['on' + event] || Prototype.emptyFunction)(transport, json);      Ajax.Responders.dispatch('on' + event, this, transport, json);    } catch (e) {      this.dispatchException(e);    }    if (event == 'Complete')      this.transport.onreadystatechange = Prototype.emptyFunction;  },  dispatchException: function(exception) {    (this.options.onException || Prototype.emptyFunction)(this, exception);    Ajax.Responders.dispatch('onException', this, exception);  }});Ajax.Updater = Class.create();Object.extend(Object.extend(Ajax.Updater.prototype, Ajax.Request.prototype), {  initialize: function(container, url, options) {    this.containers = {      success: container.success ? $(container.success) : $(container),      failure: container.failure ? $(container.failure) :        (container.success ? null : $(container))    }    this.transport = Ajax.getTransport();    this.setOptions(options);    var onComplete = this.options.onComplete || Prototype.emptyFunction;    this.options.onComplete = (function(transport, object) {      this.updateContent();      onComplete(transport, object);    }).bind(this);    this.request(url);  },  updateContent: function() {    var receiver = this.responseIsSuccess() ?      this.containers.success : this.containers.failure;    var response = this.transport.responseText;    if (!this.options.evalScripts)      response = response.stripScripts();    if (receiver) {      if (this.options.insertion) {        new this.options.insertion(receiver, response);      } else {        Element.update(receiver, response);      }    }    if (this.responseIsSuccess()) {      if (this.onComplete)        setTimeout(this.onComplete.bind(this), 10);    }  }});Ajax.PeriodicalUpdater = Class.create();Ajax.PeriodicalUpdater.prototype = Object.extend(new Ajax.Base(), {  initialize: function(container, url, options) {    this.setOptions(options);    this.onComplete = this.options.onComplete;    this.frequency = (this.options.frequency || 2);    this.decay = (this.options.decay || 1);    this.updater = {};    this.container = container;    this.url = url;    this.start();  },  start: function() {    this.options.onComplete = this.updateComplete.bind(this);    this.onTimerEvent();  },  stop: function() {    this.updater.onComplete = undefined;    clearTimeout(this.timer);    (this.onComplete || Prototype.emptyFunction).apply(this, arguments);  },  updateComplete: function(request) {    if (this.options.decay) {      this.decay = (request.responseText == this.lastText ?        this.decay * this.options.decay : 1);      this.lastText = request.responseText;    }    this.timer = setTimeout(this.onTimerEvent.bind(this),      this.decay * this.frequency * 1000);  },  onTimerEvent: function() {    this.updater = new Ajax.Updater(this.container, this.url, this.options);  }});document.getElementsByClassName = function(className, parentElement) {  var children = ($(parentElement) || document.body).getElementsByTagName('*');  return $A(children).inject([], function(elements, child) {    if (child.className.match(new RegExp("(^|\\s)" + className + "(\\s|$)")))      elements.push(child);    return elements;  });}if (!window.Element) {  var Element = new Object();}Object.extend(Element, {  visible: function(element) {    return $(element).style.display != 'none';  },  toggle: function() {    for (var i = 0; i < arguments.length; i++) {      var element = $(arguments[i]);      Element[Element.visible(element) ? 'hide' : 'show'](element);    }  },  hide: function() {    for (var i = 0; i < arguments.length; i++) {      var element = $(arguments[i]);      element.style.display = 'none';    }  },  show: function() {    for (var i = 0; i < arguments.length; i++) {      var element = $(arguments[i]);      element.style.display = '';    }  },  remove: function(element) {    element = $(element);    element.parentNode.removeChild(element);  },  update: function(element, html) {    $(element).innerHTML = html.stripScripts();    setTimeout(function() {html.evalScripts()}, 10);  },  getHeight: function(element) {    element = $(element);    return element.offsetHeight;  },  classNames: function(element) {    return new Element.ClassNames(element);  },  hasClassName: function(element, className) {    if (!(element = $(element))) return;    return Element.classNames(element).include(className);  },  addClassName: function(element, className) {    if (!(element = $(element))) return;    return Element.classNames(element).add(className);  },  removeClassName: function(element, className) {    if (!(element = $(element))) return;    return Element.classNames(element).remove(className);  },  cleanWhitespace: function(element) {    element = $(element);    for (var i = 0; i < element.childNodes.length; i++) {      var node = element.childNodes[i];      if (node.nodeType == 3 && !/\S/.test(node.nodeValue))        Element.remove(node);    }  },  empty: function(element) {    return $(element).innerHTML.match(/^\s*$/);  },  scrollTo: function(element) {    element = $(element);    var x = element.x ? element.x : element.offsetLeft,        y = element.y ? element.y : element.offsetTop;    window.scrollTo(x, y);  },  getStyle: function(element, style) {    element = $(element);    var value = element.style[style.camelize()];    if (!value) {      if (document.defaultView && document.defaultView.getComputedStyle) {        var css = document.defaultView.getComputedStyle(element, null);        value = css ? css.getPropertyValue(style) : null;      } else if (element.currentStyle) {        value = element.currentStyle[style.camelize()];      }    }    if (window.opera && ['left', 'top', 'right', 'bottom'].include(style))      if (Element.getStyle(element, 'position') == 'static') value = 'auto';    return value == 'auto' ? null : value;  },  setStyle: function(element, style) {    element = $(element);    for (name in style)      element.style[name.camelize()] = style[name];  },  getDimensions: function(element) {    element = $(element);    if (Element.getStyle(element, 'display') != 'none')      return {width: element.offsetWidth, height: element.offsetHeight};    var els = element.style;    var originalVisibility = els.visibility;    var originalPosition = els.position;    els.visibility = 'hidden';    els.position = 'absolute';    els.display = '';    var originalWidth = element.clientWidth;    var originalHeight = element.clientHeight;    els.display = 'none';    els.position = originalPosition;    els.visibility = originalVisibility;    return {width: originalWidth, height: originalHeight};  },  makePositioned: function(element) {    element = $(element);    var pos = Element.getStyle(element, 'position');    if (pos == 'static' || !pos) {      element._madePositioned = true;      element.style.position = 'relative';      if (window.opera) {        element.style.top = 0;        element.style.left = 0;      }    }  },  undoPositioned: function(element) {    element = $(element);    if (element._madePositioned) {      element._madePositioned = undefined;      element.style.position =        element.style.top =        element.style.left =        element.style.bottom =        element.style.right = '';    }  },  makeClipping: function(element) {    element = $(element);    if (element._overflow) return;    element._overflow = element.style.overflow;    if ((Element.getStyle(element, 'overflow') || 'visible') != 'hidden')      element.style.overflow = 'hidden';  },  undoClipping: function(element) {    element = $(element);    if (element._overflow) return;    element.style.overflow = element._overflow;    element._overflow = undefined;  }});var Toggle = new Object();Toggle.display = Element.toggle;Abstract.Insertion = function(adjacency) {  this.adjacency = adjacency;}Abstract.Insertion.prototype = {  initialize: function(element, content) {    this.element = $(element);    this.content = content.stripScripts();    if (this.adjacency && this.element.insertAdjacentHTML) {      try {        this.element.insertAdjacentHTML(this.adjacency, this.content);      } catch (e) {        if (this.element.tagName.toLowerCase() == 'tbody') {          this.insertContent(this.contentFromAnonymousTable());        } else {          throw e;        }      }    } else {      this.range = this.element.ownerDocument.createRange();      if (this.initializeRange) this.initializeRange();      this.insertContent([this.range.createContextualFragment(this.content)]);    }    setTimeout(function() {content.evalScripts()}, 10);  },  contentFromAnonymousTable: function() {    var div = document.createElement('div');    div.innerHTML = '<table><tbody>' + this.content + '</tbody></table>';    return $A(div.childNodes[0].childNodes[0].childNodes);  }}var Insertion = new Object();Insertion.Before = Class.create();Insertion.Before.prototype = Object.extend(new Abstract.Insertion('beforeBegin'), {  initializeRange: function() {    this.range.setStartBefore(this.element);  },  insertContent: function(fragments) {    fragments.each((function(fragment) {      this.element.parentNode.insertBefore(fragment, this.element);    }).bind(this));  }});Insertion.Top = Class.create();Insertion.Top.prototype = Object.extend(new Abstract.Insertion('afterBegin'), {  initializeRange: function() {    this.range.selectNodeContents(this.element);    this.range.collapse(true);  },  insertContent: function(fragments) {    fragments.reverse(false).each((function(fragment) {      this.element.insertBefore(fragment, this.element.firstChild);    }).bind(this));  }});Insertion.Bottom = Class.create();Insertion.Bottom.prototype = Object.extend(new Abstract.Insertion('beforeEnd'), {  initializeRange: function() {    this.range.selectNodeContents(this.element);    this.range.collapse(this.element);  },  insertContent: function(fragments) {    fragments.each((function(fragment) {      this.element.appendChild(fragment);    }).bind(this));  }});Insertion.After = Class.create();Insertion.After.prototype = Object.extend(new Abstract.Insertion('afterEnd'), {  initializeRange: function() {    this.range.setStartAfter(this.element);  },  insertContent: function(fragments) {    fragments.each((function(fragment) {      this.element.parentNode.insertBefore(fragment,        this.element.nextSibling);    }).bind(this));  }});Element.ClassNames = Class.create();Element.ClassNames.prototype = {  initialize: function(element) {    this.element = $(element);  },  _each: function(iterator) {    this.element.className.split(/\s+/).select(function(name) {      return name.length > 0;    })._each(iterator);  },  set: function(className) {    this.element.className = className;  },  add: function(classNameToAdd) {    if (this.include(classNameToAdd)) return;    this.set(this.toArray().concat(classNameToAdd).join(' '));  },  remove: function(classNameToRemove) {    if (!this.include(classNameToRemove)) return;    this.set(this.select(function(className) {      return className != classNameToRemove;    }).join(' '));  },  toString: function() {    return this.toArray().join(' ');  }}Object.extend(Element.ClassNames.prototype, Enumerable);var Field = {  clear: function() {    for (var i = 0; i < arguments.length; i++)      $(arguments[i]).value = '';  },  focus: function(element) {    $(element).focus();  },  present: function() {    for (var i = 0; i < arguments.length; i++)      if ($(arguments[i]).value == '') return false;    return true;  },  select: function(element) {    $(element).select();  },  activate: function(element) {    element = $(element);    element.focus();    if (element.select)      element.select();  }}var Form = {  serialize: function(form) {    var elements = Form.getElements($(form));

⌨️ 快捷键说明

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