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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? effects.js

?? 當前比較流行的,漂亮的JS框架,這里面用到的API文檔
?? JS
?? 第 1 頁 / 共 3 頁
字號:
// script.aculo.us effects.js v1.8.1, Thu Jan 03 22:07:12 -0500 2008// Copyright (c) 2005-2007 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us)// Contributors://  Justin Palmer (http://encytemedia.com/)//  Mark Pilgrim (http://diveintomark.org/)//  Martin Bialasinki// // script.aculo.us is freely distributable under the terms of an MIT-style license.// For details, see the script.aculo.us web site: http://script.aculo.us/ // converts rgb() and #xxx to #xxxxxx format,  // returns self (or first argument) if not convertable  String.prototype.parseColor = function() {    var color = '#';  if (this.slice(0,4) == 'rgb(') {      var cols = this.slice(4,this.length-1).split(',');      var i=0; do { color += parseInt(cols[i]).toColorPart() } while (++i<3);    } else {      if (this.slice(0,1) == '#') {        if (this.length==4) for(var i=1;i<4;i++) color += (this.charAt(i) + this.charAt(i)).toLowerCase();        if (this.length==7) color = this.toLowerCase();      }    }    return (color.length==7 ? color : (arguments[0] || this));  };/*--------------------------------------------------------------------------*/Element.collectTextNodes = function(element) {    return $A($(element).childNodes).collect( function(node) {    return (node.nodeType==3 ? node.nodeValue :       (node.hasChildNodes() ? Element.collectTextNodes(node) : ''));  }).flatten().join('');};Element.collectTextNodesIgnoreClass = function(element, className) {    return $A($(element).childNodes).collect( function(node) {    return (node.nodeType==3 ? node.nodeValue :       ((node.hasChildNodes() && !Element.hasClassName(node,className)) ?         Element.collectTextNodesIgnoreClass(node, className) : ''));  }).flatten().join('');};Element.setContentZoom = function(element, percent) {  element = $(element);    element.setStyle({fontSize: (percent/100) + 'em'});     if (Prototype.Browser.WebKit) window.scrollBy(0,0);  return element;};Element.getInlineOpacity = function(element){  return $(element).style.opacity || '';};Element.forceRerendering = function(element) {  try {    element = $(element);    var n = document.createTextNode(' ');    element.appendChild(n);    element.removeChild(n);  } catch(e) { }};/*--------------------------------------------------------------------------*/var Effect = {  _elementDoesNotExistError: {    name: 'ElementDoesNotExistError',    message: 'The specified DOM element does not exist, but is required for this effect to operate'  },  Transitions: {    linear: Prototype.K,    sinoidal: function(pos) {      return (-Math.cos(pos*Math.PI)/2) + 0.5;    },    reverse: function(pos) {      return 1-pos;    },    flicker: function(pos) {      var pos = ((-Math.cos(pos*Math.PI)/4) + 0.75) + Math.random()/4;      return pos > 1 ? 1 : pos;    },    wobble: function(pos) {      return (-Math.cos(pos*Math.PI*(9*pos))/2) + 0.5;    },    pulse: function(pos, pulses) {       pulses = pulses || 5;       return (        ((pos % (1/pulses)) * pulses).round() == 0 ?               ((pos * pulses * 2) - (pos * pulses * 2).floor()) :           1 - ((pos * pulses * 2) - (pos * pulses * 2).floor())        );    },    spring: function(pos) {       return 1 - (Math.cos(pos * 4.5 * Math.PI) * Math.exp(-pos * 6));     },    none: function(pos) {      return 0;    },    full: function(pos) {      return 1;    }  },  DefaultOptions: {    duration:   1.0,   // seconds    fps:        100,   // 100= assume 66fps max.    sync:       false, // true for combining    from:       0.0,    to:         1.0,    delay:      0.0,    queue:      'parallel'  },  tagifyText: function(element) {    var tagifyStyle = 'position:relative';    if (Prototype.Browser.IE) tagifyStyle += ';zoom:1';        element = $(element);    $A(element.childNodes).each( function(child) {      if (child.nodeType==3) {        child.nodeValue.toArray().each( function(character) {          element.insertBefore(            new Element('span', {style: tagifyStyle}).update(              character == ' ' ? String.fromCharCode(160) : character),               child);        });        Element.remove(child);      }    });  },  multiple: function(element, effect) {    var elements;    if (((typeof element == 'object') ||         Object.isFunction(element)) &&        (element.length))      elements = element;    else      elements = $(element).childNodes;          var options = Object.extend({      speed: 0.1,      delay: 0.0    }, arguments[2] || { });    var masterDelay = options.delay;    $A(elements).each( function(element, index) {      new effect(element, Object.extend(options, { delay: index * options.speed + masterDelay }));    });  },  PAIRS: {    'slide':  ['SlideDown','SlideUp'],    'blind':  ['BlindDown','BlindUp'],    'appear': ['Appear','Fade']  },  toggle: function(element, effect) {    element = $(element);    effect = (effect || 'appear').toLowerCase();    var options = Object.extend({      queue: { position:'end', scope:(element.id || 'global'), limit: 1 }    }, arguments[2] || { });    Effect[element.visible() ?       Effect.PAIRS[effect][1] : Effect.PAIRS[effect][0]](element, options);  }};Effect.DefaultOptions.transition = Effect.Transitions.sinoidal;/* ------------- core effects ------------- */Effect.ScopedQueue = Class.create(Enumerable, {  initialize: function() {    this.effects  = [];    this.interval = null;      },  _each: function(iterator) {    this.effects._each(iterator);  },  add: function(effect) {    var timestamp = new Date().getTime();        var position = Object.isString(effect.options.queue) ?       effect.options.queue : effect.options.queue.position;        switch(position) {      case 'front':        // move unstarted effects after this effect          this.effects.findAll(function(e){ return e.state=='idle' }).each( function(e) {            e.startOn  += effect.finishOn;            e.finishOn += effect.finishOn;          });        break;      case 'with-last':        timestamp = this.effects.pluck('startOn').max() || timestamp;        break;      case 'end':        // start effect after last queued effect has finished        timestamp = this.effects.pluck('finishOn').max() || timestamp;        break;    }        effect.startOn  += timestamp;    effect.finishOn += timestamp;    if (!effect.options.queue.limit || (this.effects.length < effect.options.queue.limit))      this.effects.push(effect);        if (!this.interval)      this.interval = setInterval(this.loop.bind(this), 15);  },  remove: function(effect) {    this.effects = this.effects.reject(function(e) { return e==effect });    if (this.effects.length == 0) {      clearInterval(this.interval);      this.interval = null;    }  },  loop: function() {    var timePos = new Date().getTime();    for(var i=0, len=this.effects.length;i<len;i++)       this.effects[i] && this.effects[i].loop(timePos);  }});Effect.Queues = {  instances: $H(),  get: function(queueName) {    if (!Object.isString(queueName)) return queueName;        return this.instances.get(queueName) ||      this.instances.set(queueName, new Effect.ScopedQueue());  }};Effect.Queue = Effect.Queues.get('global');Effect.Base = Class.create({  position: null,  start: function(options) {    function codeForEvent(options,eventName){      return (        (options[eventName+'Internal'] ? 'this.options.'+eventName+'Internal(this);' : '') +        (options[eventName] ? 'this.options.'+eventName+'(this);' : '')      );    }    if (options && options.transition === false) options.transition = Effect.Transitions.linear;    this.options      = Object.extend(Object.extend({ },Effect.DefaultOptions), options || { });    this.currentFrame = 0;    this.state        = 'idle';    this.startOn      = this.options.delay*1000;    this.finishOn     = this.startOn+(this.options.duration*1000);    this.fromToDelta  = this.options.to-this.options.from;    this.totalTime    = this.finishOn-this.startOn;    this.totalFrames  = this.options.fps*this.options.duration;        eval('this.render = function(pos){ '+      'if (this.state=="idle"){this.state="running";'+      codeForEvent(this.options,'beforeSetup')+      (this.setup ? 'this.setup();':'')+       codeForEvent(this.options,'afterSetup')+      '};if (this.state=="running"){'+      'pos=this.options.transition(pos)*'+this.fromToDelta+'+'+this.options.from+';'+      'this.position=pos;'+      codeForEvent(this.options,'beforeUpdate')+      (this.update ? 'this.update(pos);':'')+      codeForEvent(this.options,'afterUpdate')+      '}}');        this.event('beforeStart');    if (!this.options.sync)      Effect.Queues.get(Object.isString(this.options.queue) ?         'global' : this.options.queue.scope).add(this);  },  loop: function(timePos) {    if (timePos >= this.startOn) {      if (timePos >= this.finishOn) {        this.render(1.0);        this.cancel();        this.event('beforeFinish');        if (this.finish) this.finish();         this.event('afterFinish');        return;        }      var pos   = (timePos - this.startOn) / this.totalTime,          frame = (pos * this.totalFrames).round();      if (frame > this.currentFrame) {        this.render(pos);        this.currentFrame = frame;      }    }  },  cancel: function() {    if (!this.options.sync)      Effect.Queues.get(Object.isString(this.options.queue) ?         'global' : this.options.queue.scope).remove(this);    this.state = 'finished';  },  event: function(eventName) {    if (this.options[eventName + 'Internal']) this.options[eventName + 'Internal'](this);    if (this.options[eventName]) this.options[eventName](this);  },  inspect: function() {    var data = $H();    for(property in this)      if (!Object.isFunction(this[property])) data.set(property, this[property]);    return '#<Effect:' + data.inspect() + ',options:' + $H(this.options).inspect() + '>';  }});Effect.Parallel = Class.create(Effect.Base, {  initialize: function(effects) {    this.effects = effects || [];    this.start(arguments[1]);  },  update: function(position) {    this.effects.invoke('render', position);  },  finish: function(position) {    this.effects.each( function(effect) {      effect.render(1.0);      effect.cancel();      effect.event('beforeFinish');      if (effect.finish) effect.finish(position);      effect.event('afterFinish');    });  }});Effect.Tween = Class.create(Effect.Base, {  initialize: function(object, from, to) {    object = Object.isString(object) ? $(object) : object;    var args = $A(arguments), method = args.last(),       options = args.length == 5 ? args[3] : null;    this.method = Object.isFunction(method) ? method.bind(object) :      Object.isFunction(object[method]) ? object[method].bind(object) :       function(value) { object[method] = value };    this.start(Object.extend({ from: from, to: to }, options || { }));  },  update: function(position) {    this.method(position);  }});Effect.Event = Class.create(Effect.Base, {  initialize: function() {    this.start(Object.extend({ duration: 0 }, arguments[0] || { }));  },  update: Prototype.emptyFunction});Effect.Opacity = Class.create(Effect.Base, {  initialize: function(element) {    this.element = $(element);    if (!this.element) throw(Effect._elementDoesNotExistError);    // make this work on IE on elements without 'layout'    if (Prototype.Browser.IE && (!this.element.currentStyle.hasLayout))      this.element.setStyle({zoom: 1});    var options = Object.extend({      from: this.element.getOpacity() || 0.0,      to:   1.0    }, arguments[1] || { });    this.start(options);  },  update: function(position) {    this.element.setOpacity(position);  }});Effect.Move = Class.create(Effect.Base, {  initialize: function(element) {    this.element = $(element);    if (!this.element) throw(Effect._elementDoesNotExistError);    var options = Object.extend({      x:    0,      y:    0,      mode: 'relative'    }, arguments[1] || { });

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
五月婷婷久久综合| 处破女av一区二区| 国产成人精品影院| 欧美午夜视频网站| 久久蜜桃一区二区| 午夜精品久久久久久| 粉嫩久久99精品久久久久久夜| 91福利视频网站| 国产亚洲欧美激情| 免费观看成人鲁鲁鲁鲁鲁视频| 91女人视频在线观看| 国产丝袜在线精品| 另类中文字幕网| 欧美久久久一区| 亚洲视频一二三区| 成+人+亚洲+综合天堂| 日韩精品一区二区三区视频在线观看 | 中文成人av在线| 免费观看30秒视频久久| 欧美日韩激情一区| 一个色综合av| 91丨porny丨在线| 国产精品乱码一区二区三区软件| 精品一区二区三区在线播放| 欧美日韩国产小视频在线观看| 亚洲欧美日韩在线| 91小宝寻花一区二区三区| 国产精品乱子久久久久| 国产高清精品网站| 日本一区二区视频在线观看| 狠狠色狠狠色综合日日91app| 91精品国产福利| 天堂va蜜桃一区二区三区漫画版| 欧美日韩日日摸| 亚洲一区二区三区美女| 欧美亚洲国产一区在线观看网站| 日韩毛片精品高清免费| 色婷婷精品久久二区二区蜜臀av| 亚洲日本乱码在线观看| 91福利精品视频| 午夜精品国产更新| 91精品国产综合久久精品app| 日日欢夜夜爽一区| 欧美成人精品高清在线播放| 久久99久久99| 国产三级欧美三级日产三级99| 国产精品影视在线| 国产精品国产三级国产普通话蜜臀 | 成人福利电影精品一区二区在线观看| 国产日韩欧美a| 成+人+亚洲+综合天堂| 亚洲女人小视频在线观看| 欧美网站大全在线观看| 欧美aaaaaa午夜精品| 国产亚洲一区字幕| 99国产精品国产精品久久| 亚洲一区二区三区四区在线观看| 91精品欧美一区二区三区综合在| 狠狠久久亚洲欧美| 成人免费一区二区三区在线观看| 日本韩国欧美在线| 日本美女视频一区二区| 国产亚洲婷婷免费| 欧美性生活大片视频| 精久久久久久久久久久| 亚洲天堂成人在线观看| 正在播放亚洲一区| 成人av动漫在线| 日韩精品乱码免费| 欧美国产禁国产网站cc| 欧美日韩不卡视频| 成av人片一区二区| 美女一区二区三区| 亚洲精品乱码久久久久久久久 | 亚洲一区二区三区自拍| 精品国产乱码久久久久久老虎| 99久久综合狠狠综合久久| 日韩av不卡在线观看| 亚洲婷婷在线视频| 精品国产成人系列| 欧美亚洲动漫另类| 成人黄页毛片网站| 麻豆成人免费电影| 一区二区三区精品在线观看| 国产亚洲视频系列| 在线播放91灌醉迷j高跟美女 | 久久毛片高清国产| 欧美日韩国产美| 99久久婷婷国产精品综合| 精品一区二区免费看| 亚洲va欧美va人人爽| 国产精品久久久久久亚洲毛片| 日韩一区二区三区视频在线| 91视频在线观看| 成人三级伦理片| 国模一区二区三区白浆| 免费久久99精品国产| 亚洲综合图片区| 成人欧美一区二区三区在线播放| 精品国产123| 欧美一区二区三区免费| 欧美日韩精品欧美日韩精品| 91影院在线观看| 成人性生交大片免费| 国产一区二区三区久久悠悠色av| 丝瓜av网站精品一区二区 | 日本aⅴ精品一区二区三区 | 欧美中文字幕一二三区视频| 成人免费高清视频| 高清久久久久久| 国产成人免费在线视频| 国产综合色产在线精品| 国精产品一区一区三区mba视频 | 狠狠色丁香久久婷婷综合_中 | 成人免费看片app下载| 国产精品一区免费视频| 国产剧情一区在线| 国产麻豆精品在线观看| 国产一区二区三区免费观看| 国产精品羞羞答答xxdd| 懂色av一区二区三区免费看| 国产美女精品在线| 成人av网址在线观看| av激情综合网| 91国偷自产一区二区三区观看 | 亚洲激情五月婷婷| 一级女性全黄久久生活片免费| 一区二区三区高清不卡| 图片区小说区区亚洲影院| 日本欧美加勒比视频| 精品中文字幕一区二区小辣椒| 久久99久久99精品免视看婷婷 | 日韩高清在线观看| 另类人妖一区二区av| 国产白丝精品91爽爽久久| av网站免费线看精品| 欧洲av一区二区嗯嗯嗯啊| 欧美日韩高清不卡| 精品国产精品一区二区夜夜嗨| 久久久久久久电影| 亚洲摸摸操操av| 免费的国产精品| 国产精品一二三四| 色香色香欲天天天影视综合网| 欧美日韩不卡视频| 久久九九久久九九| 亚洲午夜精品网| 精品无人码麻豆乱码1区2区| av电影在线观看不卡| 欧美一区二区视频在线观看2022 | 91精品婷婷国产综合久久性色| 精品国产乱码久久久久久久 | 免费在线观看精品| 成人一级视频在线观看| 欧美亚洲日本一区| 欧美激情一区二区三区不卡| 亚洲动漫第一页| 国产91丝袜在线播放九色| 欧美日韩视频在线观看一区二区三区| 精品国免费一区二区三区| 亚洲欧美日韩精品久久久久| 久久99精品一区二区三区三区| 91蜜桃传媒精品久久久一区二区| 91麻豆精品久久久久蜜臀| 国产精品激情偷乱一区二区∴| 日本亚洲视频在线| 日本高清不卡aⅴ免费网站| 久久免费电影网| 日韩中文字幕区一区有砖一区| av在线不卡电影| 久久免费精品国产久精品久久久久| 亚洲午夜精品网| 91在线视频免费91| 国产喂奶挤奶一区二区三区| 日本亚洲天堂网| 欧美日韩一区不卡| 亚洲精品中文字幕在线观看| 国产精品一区免费在线观看| 日韩欧美亚洲国产精品字幕久久久 | 日日夜夜免费精品| 色综合激情久久| 亚洲国产激情av| 国产一区二区三区美女| 日韩女优av电影| 日韩 欧美一区二区三区| 欧美色中文字幕| 一区二区三区四区视频精品免费| 成人影视亚洲图片在线| 久久久99精品免费观看不卡| 精品一区二区久久久| 欧美成人精品二区三区99精品| 视频一区中文字幕国产| 欧美日韩国产首页| 亚洲国产三级在线| 欧美日韩激情一区| 亚洲高清视频在线| 欧美日韩国产高清一区二区三区 | 欧美日本一区二区| 亚洲线精品一区二区三区| 欧洲精品视频在线观看|