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

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

?? slider.js

?? grails用戶使用指南
?? JS
字號:
// Copyright (c) 2005 Marty Haught, Thomas Fuchs //// See http://script.aculo.us for more info// // Permission is hereby granted, free of charge, to any person obtaining// a copy of this software and associated documentation files (the// "Software"), to deal in the Software without restriction, including// without limitation the rights to use, copy, modify, merge, publish,// distribute, sublicense, and/or sell copies of the Software, and to// permit persons to whom the Software is furnished to do so, subject to// the following conditions:// // The above copyright notice and this permission notice shall be// included in all copies or substantial portions of the Software.//// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.if(!Control) var Control = {};Control.Slider = Class.create();// options://  axis: 'vertical', or 'horizontal' (default)//// callbacks://  onChange(value)//  onSlide(value)Control.Slider.prototype = {  initialize: function(handle, track, options) {    var slider = this;        if(handle instanceof Array) {      this.handles = handle.collect( function(e) { return $(e) });    } else {      this.handles = [$(handle)];    }        this.track   = $(track);    this.options = options || {};    this.axis      = this.options.axis || 'horizontal';    this.increment = this.options.increment || 1;    this.step      = parseInt(this.options.step || '1');    this.range     = this.options.range || $R(0,1);        this.value     = 0; // assure backwards compat    this.values    = this.handles.map( function() { return 0 });    this.spans     = this.options.spans ? this.options.spans.map(function(s){ return $(s) }) : false;    this.options.startSpan = $(this.options.startSpan || null);    this.options.endSpan   = $(this.options.endSpan || null);    this.restricted = this.options.restricted || false;    this.maximum   = this.options.maximum || this.range.end;    this.minimum   = this.options.minimum || this.range.start;    // Will be used to align the handle onto the track, if necessary    this.alignX = parseInt(this.options.alignX || '0');    this.alignY = parseInt(this.options.alignY || '0');        this.trackLength = this.maximumOffset() - this.minimumOffset();    this.handleLength = this.isVertical() ? this.handles[0].offsetHeight : this.handles[0].offsetWidth;    this.active   = false;    this.dragging = false;    this.disabled = false;    if(this.options.disabled) this.setDisabled();    // Allowed values array    this.allowedValues = this.options.values ? this.options.values.sortBy(Prototype.K) : false;    if(this.allowedValues) {      this.minimum = this.allowedValues.min();      this.maximum = this.allowedValues.max();    }    this.eventMouseDown = this.startDrag.bindAsEventListener(this);    this.eventMouseUp   = this.endDrag.bindAsEventListener(this);    this.eventMouseMove = this.update.bindAsEventListener(this);    // Initialize handles in reverse (make sure first handle is active)    this.handles.each( function(h,i) {      i = slider.handles.length-1-i;      slider.setValue(parseFloat(        (slider.options.sliderValue instanceof Array ?           slider.options.sliderValue[i] : slider.options.sliderValue) ||          slider.range.start), i);      Element.makePositioned(h); // fix IE      Event.observe(h, "mousedown", slider.eventMouseDown);    });        Event.observe(this.track, "mousedown", this.eventMouseDown);    Event.observe(document, "mouseup", this.eventMouseUp);    Event.observe(document, "mousemove", this.eventMouseMove);        this.initialized = true;  },  dispose: function() {    var slider = this;        Event.stopObserving(this.track, "mousedown", this.eventMouseDown);    Event.stopObserving(document, "mouseup", this.eventMouseUp);    Event.stopObserving(document, "mousemove", this.eventMouseMove);    this.handles.each( function(h) {      Event.stopObserving(h, "mousedown", slider.eventMouseDown);    });  },  setDisabled: function(){    this.disabled = true;  },  setEnabled: function(){    this.disabled = false;  },    getNearestValue: function(value){    if(this.allowedValues){      if(value >= this.allowedValues.max()) return(this.allowedValues.max());      if(value <= this.allowedValues.min()) return(this.allowedValues.min());            var offset = Math.abs(this.allowedValues[0] - value);      var newValue = this.allowedValues[0];      this.allowedValues.each( function(v) {        var currentOffset = Math.abs(v - value);        if(currentOffset <= offset){          newValue = v;          offset = currentOffset;        }       });      return newValue;    }    if(value > this.range.end) return this.range.end;    if(value < this.range.start) return this.range.start;    return value;  },  setValue: function(sliderValue, handleIdx){    if(!this.active) {      this.activeHandle    = this.handles[handleIdx];      this.activeHandleIdx = handleIdx;      this.updateStyles();    }    handleIdx = handleIdx || this.activeHandleIdx || 0;    if(this.initialized && this.restricted) {      if((handleIdx>0) && (sliderValue<this.values[handleIdx-1]))        sliderValue = this.values[handleIdx-1];      if((handleIdx < (this.handles.length-1)) && (sliderValue>this.values[handleIdx+1]))        sliderValue = this.values[handleIdx+1];    }    sliderValue = this.getNearestValue(sliderValue);    this.values[handleIdx] = sliderValue;    this.value = this.values[0]; // assure backwards compat        this.handles[handleIdx].style[this.isVertical() ? 'top' : 'left'] =       this.translateToPx(sliderValue);        this.drawSpans();    if(!this.dragging || !this.event) this.updateFinished();  },  setValueBy: function(delta, handleIdx) {    this.setValue(this.values[handleIdx || this.activeHandleIdx || 0] + delta,       handleIdx || this.activeHandleIdx || 0);  },  translateToPx: function(value) {    return Math.round(      ((this.trackLength-this.handleLength)/(this.range.end-this.range.start)) *       (value - this.range.start)) + "px";  },  translateToValue: function(offset) {    return ((offset/(this.trackLength-this.handleLength) *       (this.range.end-this.range.start)) + this.range.start);  },  getRange: function(range) {    var v = this.values.sortBy(Prototype.K);     range = range || 0;    return $R(v[range],v[range+1]);  },  minimumOffset: function(){    return(this.isVertical() ? this.alignY : this.alignX);  },  maximumOffset: function(){    return(this.isVertical() ?      this.track.offsetHeight - this.alignY : this.track.offsetWidth - this.alignX);  },    isVertical:  function(){    return (this.axis == 'vertical');  },  drawSpans: function() {    var slider = this;    if(this.spans)      $R(0, this.spans.length-1).each(function(r) { slider.setSpan(slider.spans[r], slider.getRange(r)) });    if(this.options.startSpan)      this.setSpan(this.options.startSpan,        $R(0, this.values.length>1 ? this.getRange(0).min() : this.value ));    if(this.options.endSpan)      this.setSpan(this.options.endSpan,         $R(this.values.length>1 ? this.getRange(this.spans.length-1).max() : this.value, this.maximum));  },  setSpan: function(span, range) {    if(this.isVertical()) {      span.style.top = this.translateToPx(range.start);      span.style.height = this.translateToPx(range.end - range.start + this.range.start);    } else {      span.style.left = this.translateToPx(range.start);      span.style.width = this.translateToPx(range.end - range.start + this.range.start);    }  },  updateStyles: function() {    this.handles.each( function(h){ Element.removeClassName(h, 'selected') });    Element.addClassName(this.activeHandle, 'selected');  },  startDrag: function(event) {    if(Event.isLeftClick(event)) {      if(!this.disabled){        this.active = true;                var handle = Event.element(event);        var pointer  = [Event.pointerX(event), Event.pointerY(event)];        if(handle==this.track) {          var offsets  = Position.cumulativeOffset(this.track);           this.event = event;          this.setValue(this.translateToValue(            (this.isVertical() ? pointer[1]-offsets[1] : pointer[0]-offsets[0])-(this.handleLength/2)          ));          var offsets  = Position.cumulativeOffset(this.activeHandle);          this.offsetX = (pointer[0] - offsets[0]);          this.offsetY = (pointer[1] - offsets[1]);        } else {          // find the handle (prevents issues with Safari)          while((this.handles.indexOf(handle) == -1) && handle.parentNode)             handle = handle.parentNode;                  this.activeHandle    = handle;          this.activeHandleIdx = this.handles.indexOf(this.activeHandle);          this.updateStyles();                  var offsets  = Position.cumulativeOffset(this.activeHandle);          this.offsetX = (pointer[0] - offsets[0]);          this.offsetY = (pointer[1] - offsets[1]);        }      }      Event.stop(event);    }  },  update: function(event) {   if(this.active) {      if(!this.dragging) this.dragging = true;      this.draw(event);      // fix AppleWebKit rendering      if(navigator.appVersion.indexOf('AppleWebKit')>0) window.scrollBy(0,0);      Event.stop(event);   }  },  draw: function(event) {    var pointer = [Event.pointerX(event), Event.pointerY(event)];    var offsets = Position.cumulativeOffset(this.track);    pointer[0] -= this.offsetX + offsets[0];    pointer[1] -= this.offsetY + offsets[1];    this.event = event;    this.setValue(this.translateToValue( this.isVertical() ? pointer[1] : pointer[0] ));    if(this.initialized && this.options.onSlide)      this.options.onSlide(this.values.length>1 ? this.values : this.value, this);  },  endDrag: function(event) {    if(this.active && this.dragging) {      this.finishDrag(event, true);      Event.stop(event);    }    this.active = false;    this.dragging = false;  },    finishDrag: function(event, success) {    this.active = false;    this.dragging = false;    this.updateFinished();  },  updateFinished: function() {    if(this.initialized && this.options.onChange)       this.options.onChange(this.values.length>1 ? this.values : this.value, this);    this.event = null;  }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线精品国精品国产尤物884a| 国产精品私人自拍| 一区二区三区精品视频在线| 成人午夜免费视频| 美女视频免费一区| 久久久激情视频| 不卡av电影在线播放| 亚洲电影一级黄| 精品国产一区久久| 风间由美性色一区二区三区| 国内精品免费**视频| 久久国产人妖系列| 国产在线不卡视频| 精品午夜一区二区三区在线观看| 免费成人小视频| 国内精品伊人久久久久av影院| 91伊人久久大香线蕉| 大白屁股一区二区视频| 日韩午夜精品电影| 精品美女在线观看| 久久久亚洲国产美女国产盗摄| 亚洲综合色网站| 日韩美女视频19| 一区二区三区日本| 99久久综合精品| 在线观看不卡一区| 亚洲丝袜精品丝袜在线| 国产成人在线观看| 91蝌蚪porny九色| 中文字幕免费观看一区| 中文在线资源观看网站视频免费不卡| 美女视频一区在线观看| 欧美日韩久久不卡| 欧美va在线播放| 久久精品久久99精品久久| 欧美日韩一区在线观看| 久久奇米777| 国产中文字幕一区| 国产亚洲一区二区在线观看| 亚洲免费观看高清完整版在线观看| 亚洲大片免费看| 欧美日韩国产乱码电影| 午夜久久久久久久久久一区二区| 精品一区二区免费在线观看| 日韩一区二区在线观看| 久久99精品久久久久久动态图| 欧美α欧美αv大片| 国产在线视频不卡二| 精品乱码亚洲一区二区不卡| 国产精品一级在线| 色综合久久中文字幕| 6080亚洲精品一区二区| 国产日韩欧美一区二区三区乱码 | 色婷婷av一区二区三区软件| 亚洲嫩草精品久久| 欧美日韩视频在线第一区| 秋霞电影一区二区| 久久精品欧美一区二区三区麻豆| 成人午夜av在线| 亚洲综合视频在线| 欧美大片在线观看一区二区| 中文字幕av在线一区二区三区| 91美女蜜桃在线| 五月天一区二区三区| 精品国产伦一区二区三区观看体验| 丁香亚洲综合激情啪啪综合| 亚洲日本丝袜连裤袜办公室| 337p亚洲精品色噜噜噜| 国产老妇另类xxxxx| 一区二区三区四区国产精品| 欧美一级黄色大片| 99麻豆久久久国产精品免费优播| 首页亚洲欧美制服丝腿| 欧美视频自拍偷拍| 亚洲欧美视频在线观看| 91精品福利在线一区二区三区 | 亚洲国产高清aⅴ视频| 欧美自拍偷拍一区| 国产精品主播直播| 亚洲午夜在线观看视频在线| 一本大道久久a久久综合| 日韩专区中文字幕一区二区| 国产亚洲1区2区3区| 欧美日韩免费观看一区二区三区| 久久99国产精品久久| 亚洲欧美日韩国产另类专区| 日韩视频在线观看一区二区| 91官网在线观看| 亚洲亚洲精品在线观看| 国产调教视频一区| 欧美日韩精品一区视频| 成人aaaa免费全部观看| 美女任你摸久久 | 免费日本视频一区| 综合网在线视频| 精品国产乱码久久久久久夜甘婷婷| 色综合久久久久综合99| 国产大陆a不卡| 精品制服美女丁香| 无码av免费一区二区三区试看| 国产精品国产三级国产普通话蜜臀| 偷拍一区二区三区四区| 亚洲欧洲日韩av| 欧美日韩1234| 色呦呦一区二区三区| 成人网页在线观看| 国产尤物一区二区在线| 精品午夜久久福利影院| 免费观看在线综合| 男女男精品视频| 五月天精品一区二区三区| 亚洲综合视频在线| 一区二区三区中文字幕在线观看| √…a在线天堂一区| 中文字幕乱码久久午夜不卡 | 国产成人综合视频| 精品一区二区三区在线观看国产| 日韩av电影免费观看高清完整版| 日韩一级欧美一级| 欧美一级淫片007| 欧美一区二区三区婷婷月色| 欧美猛男男办公室激情| 欧美日韩精品一区二区三区四区| 色94色欧美sute亚洲13| 欧美色倩网站大全免费| 欧美日韩国产一级片| 欧美人狂配大交3d怪物一区| 欧美人与z0zoxxxx视频| 日韩三级中文字幕| 久久精品亚洲国产奇米99| 欧美国产97人人爽人人喊| 欧美极品aⅴ影院| 国产精品国产三级国产有无不卡 | 综合激情成人伊人| 亚洲精品精品亚洲| 精品久久久久久最新网址| 久久亚洲一区二区三区四区| 欧美日韩一区二区欧美激情| 欧美精品aⅴ在线视频| av电影一区二区| 欧美日韩一区二区在线观看视频 | 在线观看日韩精品| 在线不卡a资源高清| 亚洲精品在线电影| 亚洲另类在线一区| 久久99精品国产麻豆不卡| 成人免费毛片嘿嘿连载视频| 91免费观看国产| 日韩欧美视频一区| 中文字幕色av一区二区三区| 亚洲国产视频一区二区| 美女一区二区久久| 亚洲一区在线观看视频| 午夜国产不卡在线观看视频| 亚洲人xxxx| 国模套图日韩精品一区二区| 九色porny丨国产精品| 国产成人自拍在线| 色婷婷精品久久二区二区蜜臀av| 欧美色综合网站| 欧美不卡一区二区三区四区| 国产欧美一区二区在线观看| 亚洲成a人片在线不卡一二三区| 日韩av中文字幕一区二区| 国产一区二区三区精品视频| 99精品国产热久久91蜜凸| 国产99久久精品| 色综合网色综合| 日韩有码一区二区三区| 国产麻豆日韩欧美久久| 国产精品亚洲一区二区三区在线 | 欧美日本一区二区在线观看| 国产午夜精品福利| 亚洲第一激情av| 国产精品一区免费在线观看| 欧美亚洲禁片免费| 国产午夜一区二区三区| 亚洲电影第三页| 国产999精品久久| 精品国产成人在线影院| 亚洲综合激情另类小说区| 精品一区二区成人精品| 色吧成人激情小说| 久久精品亚洲乱码伦伦中文| 香蕉久久一区二区不卡无毒影院 | 东方欧美亚洲色图在线| 欧美剧在线免费观看网站| 亚洲精品综合在线| 国产成人亚洲精品狼色在线| 欧美日韩高清一区二区三区| 国产精品网站一区| 丁香六月久久综合狠狠色| 欧美一区日韩一区| 亚洲一区二区三区中文字幕| 麻豆精品一区二区av白丝在线| eeuss鲁一区二区三区| 久久美女高清视频| 国产精品一二三四| 日韩一区二区免费视频| 亚洲国产精品欧美一二99|