亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? prototype.js

?? ASP開發(fā)的非常簡潔的在線報名系統(tǒng)。這個代碼在網(wǎng)上很流行
?? JS
?? 第 1 頁 / 共 4 頁
字號:
/*--------------------------------------------------------------------------*/var $F = Form.Element.getValue;/*--------------------------------------------------------------------------*/Abstract.TimedObserver = function() {}Abstract.TimedObserver.prototype = {  initialize: function(element, frequency, callback) {    this.frequency = frequency;    this.element   = $(element);    this.callback  = callback;    this.lastValue = this.getValue();    this.registerCallback();  },  registerCallback: function() {    setInterval(this.onTimerEvent.bind(this), this.frequency * 1000);  },  onTimerEvent: function() {    var value = this.getValue();    if (this.lastValue != value) {      this.callback(this.element, value);      this.lastValue = value;    }  }}Form.Element.Observer = Class.create();Form.Element.Observer.prototype = Object.extend(new Abstract.TimedObserver(), {  getValue: function() {    return Form.Element.getValue(this.element);  }});Form.Observer = Class.create();Form.Observer.prototype = Object.extend(new Abstract.TimedObserver(), {  getValue: function() {    return Form.serialize(this.element);  }});/*--------------------------------------------------------------------------*/Abstract.EventObserver = function() {}Abstract.EventObserver.prototype = {  initialize: function(element, callback) {    this.element  = $(element);    this.callback = callback;    this.lastValue = this.getValue();    if (this.element.tagName.toLowerCase() == 'form')      this.registerFormCallbacks();    else      this.registerCallback(this.element);  },  onElementEvent: function() {    var value = this.getValue();    if (this.lastValue != value) {      this.callback(this.element, value);      this.lastValue = value;    }  },  registerFormCallbacks: function() {    var elements = Form.getElements(this.element);    for (var i = 0; i < elements.length; i++)      this.registerCallback(elements[i]);  },  registerCallback: function(element) {    if (element.type) {      switch (element.type.toLowerCase()) {        case 'checkbox':        case 'radio':          Event.observe(element, 'click', this.onElementEvent.bind(this));          break;        case 'password':        case 'text':        case 'textarea':        case 'select-one':        case 'select-multiple':          Event.observe(element, 'change', this.onElementEvent.bind(this));          break;      }    }  }}Form.Element.EventObserver = Class.create();Form.Element.EventObserver.prototype = Object.extend(new Abstract.EventObserver(), {  getValue: function() {    return Form.Element.getValue(this.element);  }});Form.EventObserver = Class.create();Form.EventObserver.prototype = Object.extend(new Abstract.EventObserver(), {  getValue: function() {    return Form.serialize(this.element);  }});if (!window.Event) {  var Event = new Object();}Object.extend(Event, {  KEY_BACKSPACE: 8,  KEY_TAB:       9,  KEY_RETURN:   13,  KEY_ESC:      27,  KEY_LEFT:     37,  KEY_UP:       38,  KEY_RIGHT:    39,  KEY_DOWN:     40,  KEY_DELETE:   46,  element: function(event) {    return event.target || event.srcElement;  },  isLeftClick: function(event) {    return (((event.which) && (event.which == 1)) ||            ((event.button) && (event.button == 1)));  },  pointerX: function(event) {    return event.pageX || (event.clientX +      (document.documentElement.scrollLeft || document.body.scrollLeft));  },  pointerY: function(event) {    return event.pageY || (event.clientY +      (document.documentElement.scrollTop || document.body.scrollTop));  },  stop: function(event) {    if (event.preventDefault) {      event.preventDefault();      event.stopPropagation();    } else {      event.returnValue = false;      event.cancelBubble = true;    }  },  // find the first node with the given tagName, starting from the  // node the event was triggered on; traverses the DOM upwards  findElement: function(event, tagName) {    var element = Event.element(event);    while (element.parentNode && (!element.tagName ||        (element.tagName.toUpperCase() != tagName.toUpperCase())))      element = element.parentNode;    return element;  },  observers: false,  _observeAndCache: function(element, name, observer, useCapture) {    if (!this.observers) this.observers = [];    if (element.addEventListener) {      this.observers.push([element, name, observer, useCapture]);      element.addEventListener(name, observer, useCapture);    } else if (element.attachEvent) {      this.observers.push([element, name, observer, useCapture]);      element.attachEvent('on' + name, observer);    }  },  unloadCache: function() {    if (!Event.observers) return;    for (var i = 0; i < Event.observers.length; i++) {      Event.stopObserving.apply(this, Event.observers[i]);      Event.observers[i][0] = null;    }    Event.observers = false;  },  observe: function(element, name, observer, useCapture) {    var element = $(element);    useCapture = useCapture || false;    if (name == 'keypress' &&        (navigator.appVersion.match(/Konqueror|Safari|KHTML/)        || element.attachEvent))      name = 'keydown';    this._observeAndCache(element, name, observer, useCapture);  },  stopObserving: function(element, name, observer, useCapture) {    var element = $(element);    useCapture = useCapture || false;    if (name == 'keypress' &&        (navigator.appVersion.match(/Konqueror|Safari|KHTML/)        || element.detachEvent))      name = 'keydown';    if (element.removeEventListener) {      element.removeEventListener(name, observer, useCapture);    } else if (element.detachEvent) {      element.detachEvent('on' + name, observer);    }  }});/* prevent memory leaks in IE */Event.observe(window, 'unload', Event.unloadCache, false);var Position = {  // set to true if needed, warning: firefox performance problems  // NOT neeeded for page scrolling, only if draggable contained in  // scrollable elements  includeScrollOffsets: false,  // must be called before calling withinIncludingScrolloffset, every time the  // page is scrolled  prepare: function() {    this.deltaX =  window.pageXOffset                || document.documentElement.scrollLeft                || document.body.scrollLeft                || 0;    this.deltaY =  window.pageYOffset                || document.documentElement.scrollTop                || document.body.scrollTop                || 0;  },  realOffset: function(element) {    var valueT = 0, valueL = 0;    do {      valueT += element.scrollTop  || 0;      valueL += element.scrollLeft || 0;      element = element.parentNode;    } while (element);    return [valueL, valueT];  },  cumulativeOffset: function(element) {    var valueT = 0, valueL = 0;    do {      valueT += element.offsetTop  || 0;      valueL += element.offsetLeft || 0;      element = element.offsetParent;    } while (element);    return [valueL, valueT];  },  positionedOffset: function(element) {    var valueT = 0, valueL = 0;    do {      valueT += element.offsetTop  || 0;      valueL += element.offsetLeft || 0;      element = element.offsetParent;      if (element) {        p = Element.getStyle(element, 'position');        if (p == 'relative' || p == 'absolute') break;      }    } while (element);    return [valueL, valueT];  },  offsetParent: function(element) {    if (element.offsetParent) return element.offsetParent;    if (element == document.body) return element;    while ((element = element.parentNode) && element != document.body)      if (Element.getStyle(element, 'position') != 'static')        return element;    return document.body;  },  // caches x/y coordinate pair to use with overlap  within: function(element, x, y) {    if (this.includeScrollOffsets)      return this.withinIncludingScrolloffsets(element, x, y);    this.xcomp = x;    this.ycomp = y;    this.offset = this.cumulativeOffset(element);    return (y >= this.offset[1] &&            y <  this.offset[1] + element.offsetHeight &&            x >= this.offset[0] &&            x <  this.offset[0] + element.offsetWidth);  },  withinIncludingScrolloffsets: function(element, x, y) {    var offsetcache = this.realOffset(element);    this.xcomp = x + offsetcache[0] - this.deltaX;    this.ycomp = y + offsetcache[1] - this.deltaY;    this.offset = this.cumulativeOffset(element);    return (this.ycomp >= this.offset[1] &&            this.ycomp <  this.offset[1] + element.offsetHeight &&            this.xcomp >= this.offset[0] &&            this.xcomp <  this.offset[0] + element.offsetWidth);  },  // within must be called directly before  overlap: function(mode, element) {    if (!mode) return 0;    if (mode == 'vertical')      return ((this.offset[1] + element.offsetHeight) - this.ycomp) /        element.offsetHeight;    if (mode == 'horizontal')      return ((this.offset[0] + element.offsetWidth) - this.xcomp) /        element.offsetWidth;  },  clone: function(source, target) {    source = $(source);    target = $(target);    target.style.position = 'absolute';    var offsets = this.cumulativeOffset(source);    target.style.top    = offsets[1] + 'px';    target.style.left   = offsets[0] + 'px';    target.style.width  = source.offsetWidth + 'px';    target.style.height = source.offsetHeight + 'px';  },  page: function(forElement) {    var valueT = 0, valueL = 0;    var element = forElement;    do {      valueT += element.offsetTop  || 0;      valueL += element.offsetLeft || 0;      // Safari fix      if (element.offsetParent==document.body)        if (Element.getStyle(element,'position')=='absolute') break;    } while (element = element.offsetParent);    element = forElement;    do {      valueT -= element.scrollTop  || 0;      valueL -= element.scrollLeft || 0;    } while (element = element.parentNode);    return [valueL, valueT];  },  clone: function(source, target) {    var options = Object.extend({      setLeft:    true,      setTop:     true,      setWidth:   true,      setHeight:  true,      offsetTop:  0,      offsetLeft: 0    }, arguments[2] || {})    // find page position of source    source = $(source);    var p = Position.page(source);    // find coordinate system to use    target = $(target);    var delta = [0, 0];    var parent = null;    // delta [0,0] will do fine with position: fixed elements,    // position:absolute needs offsetParent deltas    if (Element.getStyle(target,'position') == 'absolute') {      parent = Position.offsetParent(target);      delta = Position.page(parent);    }    // correct by body offsets (fixes Safari)    if (parent == document.body) {      delta[0] -= document.body.offsetLeft;      delta[1] -= document.body.offsetTop;    }    // set position    if(options.setLeft)   target.style.left  = (p[0] - delta[0] + options.offsetLeft) + 'px';    if(options.setTop)    target.style.top   = (p[1] - delta[1] + options.offsetTop) + 'px';    if(options.setWidth)  target.style.width = source.offsetWidth + 'px';    if(options.setHeight) target.style.height = source.offsetHeight + 'px';  },  absolutize: function(element) {    element = $(element);    if (element.style.position == 'absolute') return;    Position.prepare();    var offsets = Position.positionedOffset(element);    var top     = offsets[1];    var left    = offsets[0];    var width   = element.clientWidth;    var height  = element.clientHeight;    element._originalLeft   = left - parseFloat(element.style.left  || 0);    element._originalTop    = top  - parseFloat(element.style.top || 0);    element._originalWidth  = element.style.width;    element._originalHeight = element.style.height;    element.style.position = 'absolute';    element.style.top    = top + 'px';;    element.style.left   = left + 'px';;    element.style.width  = width + 'px';;    element.style.height = height + 'px';;  },  relativize: function(element) {    element = $(element);    if (element.style.position == 'relative') return;    Position.prepare();    element.style.position = 'relative';    var top  = parseFloat(element.style.top  || 0) - (element._originalTop || 0);    var left = parseFloat(element.style.left || 0) - (element._originalLeft || 0);    element.style.top    = top + 'px';    element.style.left   = left + 'px';    element.style.height = element._originalHeight;    element.style.width  = element._originalWidth;  }}// Safari returns margins on body which is incorrect if the child is absolutely// positioned.  For performance reasons, redefine Position.cumulativeOffset for// KHTML/WebKit only.if (/Konqueror|Safari|KHTML/.test(navigator.userAgent)) {  Position.cumulativeOffset = function(element) {    var valueT = 0, valueL = 0;    do {      valueT += element.offsetTop  || 0;      valueL += element.offsetLeft || 0;      if (element.offsetParent == document.body)        if (Element.getStyle(element, 'position') == 'absolute') break;      element = element.offsetParent;    } while (element);    return [valueL, valueT];  }}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区电影| 久久亚洲精品小早川怜子| 欧美一级艳片视频免费观看| 精品va天堂亚洲国产| 国产精品久久久久久妇女6080| 亚洲免费资源在线播放| 蜜臀av一区二区在线免费观看| 国产69精品久久777的优势| 欧美综合亚洲图片综合区| 欧美电影免费观看完整版| 中文字幕中文字幕一区二区| 午夜精品久久一牛影视| 国产成人精品亚洲日本在线桃色| 在线视频国产一区| 国产网红主播福利一区二区| 亚洲成人综合在线| 国产69精品久久99不卡| 欧美精品1区2区| 国产精品国产三级国产有无不卡| 亚洲1区2区3区4区| 高清免费成人av| 日韩视频国产视频| 亚洲欧美一区二区三区久本道91| 久久99国产精品久久99| 色综合久久66| 国产亚洲福利社区一区| 婷婷一区二区三区| 99久久er热在这里只有精品66| 日韩欧美综合在线| 又紧又大又爽精品一区二区| 国产乱码精品一区二区三区av | 久久亚洲免费视频| 亚洲成在人线免费| 91美女片黄在线观看91美女| 欧美精品一区二区三区蜜臀 | 欧美一区二区女人| 一区二区三区四区五区视频在线观看| 国产精品一二三区| 欧美一区二区女人| 午夜欧美2019年伦理 | 亚洲1区2区3区视频| 91影院在线观看| 久久精品一区二区三区不卡 | 久久久久久9999| 五月天激情小说综合| 色婷婷av一区二区三区软件| 中文字幕不卡在线播放| 国模套图日韩精品一区二区| 欧美吞精做爰啪啪高潮| 1024成人网| 风流少妇一区二区| 久久午夜电影网| 久久国产精品99精品国产| 欧美日韩国产精品自在自线| 夜色激情一区二区| 99精品视频在线观看| 久久精品视频一区二区| 国产精品99久久久久久久vr | av激情亚洲男人天堂| 久久伊人中文字幕| 久久电影网站中文字幕| 91精品国产综合久久久久久久久久| 一区二区三区欧美日| 91免费看视频| 亚洲欧美国产三级| 91视频.com| 亚洲精品久久嫩草网站秘色| 97se亚洲国产综合自在线不卡| 国产精品无遮挡| 成人免费看视频| 国产精品免费免费| av色综合久久天堂av综合| 日韩一区在线看| 色系网站成人免费| 一区二区欧美视频| 欧美精品在线观看播放| 视频一区二区中文字幕| 日韩免费高清av| 国产真实乱对白精彩久久| 久久久国产精品午夜一区ai换脸| 国产精品一区二区在线观看不卡| 国产亚洲欧美色| 99re66热这里只有精品3直播| 亚洲狠狠丁香婷婷综合久久久| 91国内精品野花午夜精品| 亚洲综合视频网| 这里只有精品99re| 国产一区二区三区免费播放| 国产精品色一区二区三区| 一本一道久久a久久精品综合蜜臀| 夜色激情一区二区| 日韩视频在线永久播放| 国产成人av一区二区三区在线 | 99re热这里只有精品视频| 一区二区三区在线视频观看| 欧美日韩高清一区二区不卡 | 亚洲国产精品精华液2区45| 波多野结衣精品在线| 一区二区三区免费在线观看| 欧美一区二区三区免费视频| 国产美女视频91| 亚洲精品videosex极品| 欧美精品123区| 国产成人av影院| 亚洲最大成人综合| 欧美大片在线观看| 暴力调教一区二区三区| 五月综合激情日本mⅴ| 久久亚洲精精品中文字幕早川悠里 | 欧美性色黄大片| 男女男精品网站| 国产精品久久毛片a| 欧美色男人天堂| 国产一区二区三区精品视频| 国产精品网曝门| 欧美午夜不卡在线观看免费| 国产一区啦啦啦在线观看| 亚洲欧美日韩久久| 欧美成人vr18sexvr| 91视频免费观看| 蜜桃视频一区二区三区在线观看| 国产欧美中文在线| 5858s免费视频成人| 高清在线观看日韩| 日韩影院精彩在线| 亚洲欧美一区二区三区孕妇| 日韩精品一区二区三区四区视频| 99re热这里只有精品视频| 六月丁香综合在线视频| 亚洲码国产岛国毛片在线| 精品福利在线导航| 欧美三日本三级三级在线播放| 国产精品自在在线| 亚洲成人777| 1000精品久久久久久久久| 日韩欧美另类在线| 在线免费一区三区| 成人精品高清在线| 国模套图日韩精品一区二区| 午夜精品福利在线| 自拍偷拍国产精品| 久久精品日产第一区二区三区高清版 | 久久综合九色综合欧美就去吻| 色综合色综合色综合| 国产成人午夜电影网| 美女性感视频久久| 午夜亚洲福利老司机| 亚洲视频在线观看三级| 国产午夜精品福利| 欧美一区二区视频在线观看| 91久久人澡人人添人人爽欧美| 国产一区免费电影| 久久av中文字幕片| 午夜精品久久久久久久99水蜜桃 | 欧美视频一区在线| 99热精品一区二区| 国产高清精品久久久久| 久久www免费人成看片高清| 日韩激情在线观看| 亚洲国产精品一区二区久久 | 欧美日韩国产另类不卡| 在线免费观看不卡av| 91在线你懂得| av中文字幕在线不卡| 国产99久久久久久免费看农村| 蜜臀av性久久久久蜜臀aⅴ流畅| 性久久久久久久久久久久| 一区二区日韩电影| 亚洲自拍与偷拍| 亚洲美女在线国产| 一区二区三区精密机械公司| 中文字幕人成不卡一区| 国产精品每日更新| 国产精品三级电影| 国产精品午夜春色av| 亚洲国产精品ⅴa在线观看| 国产视频一区在线观看| 久久综合色婷婷| 久久久国产一区二区三区四区小说 | 午夜成人免费电影| 日韩国产精品久久久久久亚洲| 亚洲高清视频中文字幕| 五月天婷婷综合| 日韩高清在线不卡| 蜜臀精品一区二区三区在线观看| 青娱乐精品视频| 精品伊人久久久久7777人| 精品一区精品二区高清| 国产精品中文欧美| 成人免费视频网站在线观看| 99re66热这里只有精品3直播| 色综合天天做天天爱| 91高清视频免费看| 欧美人动与zoxxxx乱| 91精品国产综合久久精品麻豆 | 国产麻豆9l精品三级站| 国产馆精品极品| 99re成人精品视频| 欧美色视频在线观看| 日韩欧美国产高清|