javascript+HTML5自定义元素播放焦点图动画


Posted in Javascript onFebruary 21, 2016

这是一款基于HTML5的焦点图动画,它和其他焦点图不同的地方在于,它播放的不仅仅是图片,而是可以自定义控制的网页元素。它不仅在图片间切换有过渡动画效果,而且在切换时图片中的元素也将出现动画效果,比如图中的文字移动、打散、重新组合等,这款HTML5动画图片播放器算得上是高端大气上档次。

效果图:

javascript+HTML5自定义元素播放焦点图动画

HTML代码

<div class="parallax-bg" id="slider-wrap">
 <div class="slider parallax-bg" id="slider">
   <div class="slider-sections sandbox"> 
 <section class="first">
      <img alt="Kendo UI" src="images/home-banner-1.png"/>
      <div class="text">
       <h2>SmartSite Ver 2.2<br />智能网站管理系统 </h2>
       <p class="copy">采用前后台完全分离技术,通过标签(支持标签循环嵌套、判断标签、自定义标签、文件循环嵌套等)加模板技术.全站生成纯静态页。</p>
       <p class="button"><a href="#" onclick="_gaq.push(['_trackPageview', '#']);">Download</a> <a class="dimmed" onclick="_gaq.push(['_trackPageview', '#']);" href="#">Learn More</a></p>
      </div>
    </section>
 <section>
      <img src="images/dataviz-home-image-q2.png" alt="Kendo UI" />
      <div class="text" style="padding-top: 10px;">
       <h2>企业网站管理系统</h2>
       <p class="copy">单页面、单页面索引、新闻、产品展示、下载、友情链接、网上商城,在线支付、配送、支付方式管理、广告等模块。</p>
       <p class="button"><a href="#" onclick="_gaq.push(['_trackPageview', '#']);">Download</a> <a class="dimmed" onclick="_gaq.push(['_trackPageview', '#']);" href="#">Learn More</a></p>
      </div>
    </section>
 <section>
      <img src="images/home_banner_web-q2.png" alt="Kendo UI" />
      <div class="text">
       <h2>智能移动网站管理系统</h2>
       <p class="copy">基于jquery.Mobile、HTML5技术框架,前后台完全分离,采用标签加模板技术,全站生成纯静态页。</p>
       <p class="button"><a href="#" onclick="_gaq.push(['_trackPageview', '#']);">Download</a> <a class="dimmed" onclick="_gaq.push(['_trackPageview', '#']);" href="#">Learn More</a></p>
      </div>
    </section>
   </div>
  </div>
  <a class="slider-prev" href="javascript: void(0)">?</a> <a class="slider-next" href="javascript: void(0)">?</a>
</div>

CSS代码:

这里列出的是这个焦点图相关的核心CSS代码。

.slider section {display: none;}
.slider section.first {display: block;}

.slider-sections, .slider-sections section {width: 861px; height: 335px;}

.slider-sections {margin: 0 auto; position: relative;}
.slider-sections section {position: absolute; top: 0; left: 0px; }

.header-content h2 
{
 font:400 32px/1.2 "microsoft yahei", Tahoma, arial, sans-serif;
 color: #fff;
 margin: 0 0 26px;
}
.header-content p 
{
 margin: 0 0 30px;
}

.header-content .centered-content
{
 padding-top: 30px;
 padding-bottom: 10px;
}

.button {
 float: left;
 width: auto !important;
 list-style: none;
}
 .button a,
 .button button,
 .button input { /* Standard black button */
 font-size: 15px;
 /*font-family: 'lucida sans',arial,helvetica,sans-serif;*/
 line-height: 18px;
 color: #fff !important;

 text-decoration: none;

 padding: 5px 14px 6px 13px;
 display: block;
 width: auto;
 position: relative;
 z-index: 2;

  border: none;
  -moz-border-radius: 3px;
 border-radius: 3px;
 cursor: pointer;

 background: #313131; /* Old browsers */
 background: -moz-linear-gradient(top, #313131 0%, #222222 100%); /* FF3.6+ */
 background: -webkit-linear-gradient(top, #313131 0%,#222222 100%); /* Chrome10+,Safari5.1+ */
 background: -o-linear-gradient(top, #313131 0%,#222222 100%); /* Opera11.10+ */
 background: -ms-linear-gradient(top, #313131 0%,#222222 100%); /* IE10+ */
 background: linear-gradient(top, #313131 0%,#222222 100%); /* W3C */

 -webkit-transition: all 0.3s ease;
 -moz-transition: all 0.3s ease;
 -o-transition: all 0.3s ease;
 transition: all 0.3s ease;
 }

 .button a:hover,
 .button input:hover,
 .button button:hover,
 .button a:focus,
 .button input:focus,
 .button button:focus
 {
 background: #464646; /* Old browsers */
 background: -moz-linear-gradient(top, #464646 0%, #393939 100%); /* FF3.6+ */
 background: -webkit-linear-gradient(top, #464646 0%,#393939 100%); /* Chrome10+,Safari5.1+ */
 background: -o-linear-gradient(top, #464646 0%,#393939 100%); /* Opera11.10+ */
 background: -ms-linear-gradient(top, #464646 0%,#393939 100%); /* IE10+ */
 background: linear-gradient(top, #464646 0%,#393939 100%); /* W3C */
 }

 header .header-content .button a,
 #content .button a:hover
 {
  text-decoration: none;
 }

.header-content .beta-ribbons {
 position: absolute; 
 height: 120px;
 width: 85px;
 text-indent: -200px;
 overflow: hidden;
 background: url(../images/kendo-ribbons.png) no-repeat 0 0;
}

.header-content .beta-ribbons.ribbon-1 {
 background-position: -170px 0;
 top: -3px;
 right: -145px;
}

.header-content p.copy .beta-ribbons.ribbon-1 {
 top: -135px;
 left: 900px;
}

.header-content .beta-ribbons.ribbon-4 {
 background-position: -255px 0;
 left: -62px;
 top: -30px;
 z-index: 10;
 text-indent: -2000px;
}

JavaScript代码:

下面是这个焦点图插件的代码。

/**
* @author Alexander Farkas
* v. 1.22
*/
(function ($)
{
 if (!document.defaultView || !document.defaultView.getComputedStyle)
 { // IE6-IE8
  var oldCurCSS = $.curCSS;
  $.curCSS = function (elem, name, force)
  {
   if (name === 'background-position')
   {
    name = 'backgroundPosition';
   }
   if (name !== 'backgroundPosition' || !elem.currentStyle || elem.currentStyle[name])
   {
    return oldCurCSS.apply(this, arguments);
   }
   var style = elem.style;
   if (!force && style && style[name])
   {
    return style[name];
   }
   return oldCurCSS(elem, 'backgroundPositionX', force) + ' ' + oldCurCSS(elem, 'backgroundPositionY', force);
  };
 }

 var oldAnim = $.fn.animate;
 $.fn.animate = function (prop)
 {
  if ('background-position' in prop)
  {
   prop.backgroundPosition = prop['background-position'];
   delete prop['background-position'];
  }
  if ('backgroundPosition' in prop)
  {
   prop.backgroundPosition = '(' + prop.backgroundPosition;
  }
  return oldAnim.apply(this, arguments);
 };

 function toArray(strg)
 {
  strg = strg.replace(/left|top/g, '0px');
  strg = strg.replace(/right|bottom/g, '100%');
  strg = strg.replace(/([0-9\.]+)(\s|\)|$)/g, "$1px$2");
  var res = strg.match(/(-?[0-9\.]+)(px|\%|em|pt)\s(-?[0-9\.]+)(px|\%|em|pt)/);
  return [parseFloat(res[1], 10), res[2], parseFloat(res[3], 10), res[3]];
 }

 $.fx.step.backgroundPosition = function (fx)
 {
  if (!fx.bgPosReady)
  {
   var start = $.curCSS(fx.elem, 'backgroundPosition');
   if (!start)
   {//FF2 no inline-style fallback
    start = '0px 0px';
   }

   start = toArray(start);
   fx.start = [start[0], start[2]];
   var end = toArray(fx.end);
   fx.end = [end[0], end[2]];

   fx.unit = [end[1], end[3]];
   fx.bgPosReady = true;
  }
  //return;
  var nowPosX = [];
  nowPosX[0] = ((fx.end[0] - fx.start[0]) * fx.pos) + fx.start[0] + fx.unit[0];
  nowPosX[1] = ((fx.end[1] - fx.start[1]) * fx.pos) + fx.start[1] + fx.unit[1];
  fx.elem.style.backgroundPosition = nowPosX[0] + ' ' + nowPosX[1];

 };
})(jQuery);

/*
tlrkSlider

 example usage:

 $("#slider").tlrkSlider({
  autoStart: false,
  elements: {
  "img": {delay: 10},
  "h2": {delay: 500},
  ".copy": {delay: 800},
  ".button": {delay: 1000}
  }
 });

 to go to a specific frame:
 $("#slider").tlrkSlider("go", position);
 "position" can have one of the following values:
 "next", "prev", "first", "last", "+1", "-1" or a numeric value

 to start/stop the automatic loop:
 $("#slider").tlrkSlider("start");
 $("#slider").tlrkSlider("stop");

 to change the delay between automatic transitions:
 $("#slider").tlrkSlider("option", "delayAnimation", 1000);

 to change any option:
 $("#slider").tlrkSlider("option", option_name, option_value);

 Changing the "elements" object is not tested.

 Changing the following options: "navigation", "navigationClass", "framesSelector", "autoStart" won't have any effect for now.
 They are used only during the initialization.

 $("#slider").data("tlrkSlider") will return the plugin instance and the methods/properties can be accessed from there.

 The plugin contructor defaults are accessable through TlrkSlider.defaults

 The function that actually sweep the elements in/out can be overriden from
 TlrkSlider.prototype._animationIn and TlrkSlider.prototype._animationOut

 See sweepIn/sweepOut 

 */

;(function( $, window, document, undefined ){

 // utility function that generates the "dots" navigation
 function generateNavigation($el, count, config) {
 var i, html = "",
  width = count * 24;

 html += "<ol class='" + config.navigationClass + "' style='margin-left: -" + width/2 + "px; width: " + width + "px'>";
 for (i = 0; i < count; i++) {
  html += "<li><a " + (i === 0 ? "class='selected'" : "" ) + " href='#" + (i) + "'>slide</a></li>";
 }
 html += "</ol>";

 $el.append(html);
 }

 function sweepOut($el, windowWidth) {
 var dfr = $.Deferred(),
  pos = $el.position(),
  width = $el.width(),
  delta, final,
  options = $el.data("tlrkAnimOptions");

 windowWidth = windowWidth || $(window).width(); // check if the windowWidth is passed, if not - get it

 delta = windowWidth - pos.left;
 final = -(delta);

 setTimeout(function(){
  $el.animate({left: final, opacity: "toggle"}, options.speed, options.easing, function(){
  dfr.resolve();
  });
 }, options.delay);

 return dfr.promise();
 }

 function sweepIn($el, windowWidth, frameLeft) {
 var dfr = $.Deferred(),
  options = $el.data("tlrkAnimOptions"),
  positionData = $el.data("tlrkOriginalPos"),
  final = positionData.position.left,
  rightEdge;

 windowWidth = windowWidth || $(window).width(); // check if the windowWidth is passed, if not - get it

 $el.css({opacity: 0, display: "block"}); // move it outside the right edge of the screen
 $el.css("left", function(current){
  return current + windowWidth - frameLeft;
 });

 setTimeout(function(){
  $el.animate({left: final, opacity: 1}, options.speed, options.easing, function(){
  dfr.resolve();
  });
 }, options.delay);

 return dfr.promise();
 }

 // two pass function that first iterates all the elements and gets their position/width/height
 // and then sets their position to absolute
 function absolutize($elements) {

 // todo - move it to separate function and do it just once
 // gather the original position/dimension data for all elements
 $elements.each(function(){
  var $t = $(this);

  if ($t.data("tlrkOriginalPos")) return

  $t.data("tlrkOriginalPos", {
  position: $t.position(),
  width: $t.width(),
  height: $t.height(),
  css_pos: $t.css("position"),
  css_left: $t.css("left"),
  css_top: $t.css("top"),
  css_width: $t.css("width") || "auto",
  css_height: $t.css("height") || "auto"
  });

 });

 // set the absolute position
 $elements.each(function(){
  var $t = $(this),
   opos = $t.data("tlrkOriginalPos");

  $t.css({
  position: "absolute",
  left: opos.position.left,
  top: opos.position.top,
  width: opos.width,
  height: opos.height
  });
 });
 }

 function restoreFrameElements($elements) {
 $elements.each(function(){
  var $t = $(this),
   opos = $t.data("tlrkOriginalPos");

  if (!opos) return

  $t.css({
  position: opos.css_pos,
  left: opos.css_left,
  top: opos.css_top,
  width: opos.css_width,
  height: opos.css_height
  });
 });

 }

 var TlrkSlider = function( elem, options ){
  this.elem = elem;
  this.$elem = $(elem);
  this.options = options;
 };

 // the plugin prototype
 TlrkSlider.prototype = {
 defaults: {

  defaultElementOptions: {
  speed: 1200,
  easing: "easeInOutBack",
  // interval before the element starts moving when the fadeIn/Out functions are called
  // it's a good idea to give different delays for the different elements
  // if all have the same delay they'll start moving all together
  delay: 100 
  },

  // dispose elements are these that are not included in the elements object
  // but affect the document flow and will be fadedIn/Out
  disposeDelay: 100, // delay for the dispose elements
  disposeSpeed: 1000, // how quickly they'll fadeOut/In

  delayBetweenTransition: 1000, // time between starting fadeOut and fadeIn
  delayAnimation: 7000, // time between auto changing the current frame

  loop: true, // if true when clicking next on the last frame the slider jumps to the first one

  autoStart: true, // start the automatic looping through the frames on init

  framesSelector: "section", // selector for the frames inside the slider

  elements: {
  "p": {delay: 100, speed: 1000, easing: "easeInOutBack"}
  },

  navigation: true, // the dots navigation on the bottom
  navigationClass: "slider-nav",

  // callbacks
  // another way to "catch" these events is with
  // $(-slider-element-).bind("animationStart")
  animationStart: null,
  animationEnd: null
 },

 init: function() {
  var c, e, element, $element,
   that = this,
   $firstFrame;

  c = this.config = $.extend({}, this.defaults, this.options);

  this.elem.style.position = "relative"; // make the wrapping element relative

  // basics
  this.$frames = this.$elem.find(c.framesSelector);
  this.framesCount = this.$frames.length;
  this.currentFrame = 0;
  this.queue = [];

  this._$elementsByFrame = {};
  this._$disposeElementsByFrame = {};

  for (i = 0; i < this.framesCount; i++) {
  this._$elementsByFrame[i] = this._getFrameElements(i); // cache the $elements by frame
  this._$disposeElementsByFrame[i] = this._getDisposeFrameElements(i); // cache the rest of the tree for each frame
  }

  if (c.navigation) {
  generateNavigation(this.$elem, this.framesCount, c);
  this.$navigation = this.$elem.find("."+c.navigationClass);
  }

  // bindings
  this.$elem.find(".slider-nav").delegate("a", "click", function(e){
  var frame = this.getAttribute("href").split("#")[1];
  that.go.call(that, frame);
  return false;
  });

  this.$elem // internal bindings for the callbacks
  .bind("animationStart", function(){
   if ($.isFunction(c.animationStart)) {c.animationStart.apply(that, arguments);}
  })
  .bind("animationEnd", function(){
   if ($.isFunction(c.animationEnd)) {c.animationEnd.apply(that, arguments);}
  })
  ;

  // start animation?
  if (c.autoStart) {
  this.start();
  } else {
  this.running = false;
  }

  return this;
 },

 start: function(instant) {
  var that = this;

  if (this.timer) { // we'll clear the current timer
  window.clearTimeout(this.timer);
  }

  this.running = true;

  if (instant) {
  that.nextFrame();
  } else {
  this.timer = window.setTimeout(function(){ that.nextFrame.call(that) }, that.config.delayAnimation);
  }
 },

 stop: function() {
  if (!this.running) return; // we are not running

  this.running = false;
  window.clearTimeout(this.timer);
 },

 // main function for changing frames
 selectFrame: function(frame, dfr) {
  var c = this.config, // shorthand for the config
   that = this,
   dfr = dfr || $.Deferred(),
   dFadeIn = $.Deferred(),
   dFadeOut = $.Deferred();

  if (isNaN(frame) || frame < 0 || frame > this.framesCount || frame === this.currentFrame) {
  dfr.reject();
  return dfr.promise();
  }

  // clear the animation loop interval if the animation is running
  if (this.running && this.timer) { 
  window.clearTimeout(this.timer);
  }

  // check if we are currenly running an animation.
  if (this.animated && this.queue.length > 0) {
  // wait for the last item in the queue to finish
  this.queue[this.queue.length-1].done(function(){
   that.selectFrame(frame, dfr); // and call again the selectFrame
  })
  return dfr.promise();
  }

  this.animated = true;
  this.$elem.trigger("animationStart", [this, frame]);

  this.queue.push(dfr);

  // fade the frames
  dFadeOut = this._fadeOutFrame(this.currentFrame);

  // hide the fadetout frame
  dFadeOut.done(function(){
  that.$frames.eq(that.currentFrame).hide();
  });

  window.setTimeout(function(){ // then wait delayBetweenTransition and fadeIn the new frame
  dFadeIn = that._fadeInFrame.call(that, frame).done(function(){
   // when both the fadeIn and fadeOut are done we'll resolve the selectFrame promise
   $.when(dFadeOut, dFadeIn).done(function(){
   that.animated = false;
   that.queue.shift();
   that.$elem.trigger("animationEnd", [that]);
   that.currentFrame = frame;
   dfr.resolve();
   });
  });
  }, c.delayBetweenTransition);

  // navigation html change
  if (this.config.navigation) {
  this.$navigation.find(".selected").removeClass("selected").end()
   .find("a").eq(frame).addClass("selected");
  }

  dfr.done(function(){ // we'll resume the loop animation after the transitions are done
  if (that.running) {
   that.start();
  }
  });

  return dfr.promise();
 },

 _fadeFrame: function(frame, callback, direction) {
  var dfr = $.Deferred(),
   $frame = this.$frames.eq(frame),
   $elements = this._$elementsByFrame[frame],
   windowWidth = $(window).width(), // cache it before the animations, so we don't have to check it for each element 
   i, len,
   that = this,
   elementAnimations = [],
   $disposeElements = this._$disposeElementsByFrame[frame],
   $affectedElements,
   frameLeft = $frame.offset().left;

  direction = direction || "out";

  if (!$.isFunction(callback)) return; // do nothing if there's no callback passed

  $affectedElements = $elements.add($disposeElements);

  // position absolute the animation and dispose elements
  absolutize($affectedElements);

  // toggle the dispose elements
  if ($disposeElements.length > 0) {
  window.setTimeout(function(){
   $disposeElements[direction === "out" ? "fadeOut" : "fadeIn"](that.config.disposeSpeed);
  }, this.config.disposeDelay);
  }

  // invoke the callback for each element
  // the callback must return a promise
  $elements.each(function(){
  elementAnimations.push( callback.call(that, $(this), windowWidth, frameLeft) );
  });

  // wait for all the elements to finish their animation
  $.when.apply(this, elementAnimations).done(function(){
  //restoreFrameElements($affectedElements); // and restore the elements' position
  dfr.resolve(); // resolve the fade function
  });

  return dfr.promise();
 },

 _fadeOutFrame: function(frame) {
  var dfr = $.Deferred(),
   $frame = this.$frames.eq(frame),
   $disposeElements = this._$disposeElementsByFrame[frame];

  this._fadeFrame(frame, this._animationOut, "out").done(function(){
  dfr.resolve();
  })

  return dfr.promise();
 },

 _fadeInFrame: function(frame) {
  var dfr = $.Deferred(),
   $frame = this.$frames.eq(frame),
   $elements = this._$elementsByFrame[frame];

  this._restoreFrame(frame);

  $frame.show();

  this._fadeFrame(frame, this._animationIn, "in").done(function(){
  dfr.resolve();
  });

  return dfr.promise();
 },

 _restoreFrame: function(frame){
  if (!frame) return
  restoreFrameElements( this._$elementsByFrame[frame].add(this._$disposeElementsByFrame[frame]) );
 },

 nextFrame: function() {
  var frame = this.currentFrame+1,
   dfr = $.Deferred();

  if (frame > this.framesCount-1) {
  if (this.config.loop) {
   frame = 0;
  } else {
   dfr.reject();
  }
  };

  this.selectFrame(frame).done(function(){
  dfr.resolve();
  });

  return dfr.promise();
 },

 prevFrame: function() {
  var frame = this.currentFrame-1,
   dfr = $.Deferred();

  if (frame < 0) {
  if (this.config.loop) {
   frame = this.framesCount-1;
  } else {
   dfr.reject();
   return dfr.promise();
  }
  }

  this.selectFrame(frame).done(function(){
  dfr.resolve();
  });

  return dfr.promise();
 },

 go: function(str) { // shorthand
  switch (str) {
  case "next":
  case "+1":
   this.nextFrame();
   break;

  case "prev":
  case "-1":
   this.prevFrame();
   break;

  case "first":
   this.selectFrame(0);
   break;

  case "last":
   this.selectFrame(this.framesCount-1);
   break;

  default:
   if (isNaN(str)) return;
   this.selectFrame(Number(str));
  }
 },

 // returns jquery collection of animation elements
 _getFrameElements: function(frame) { 
  var $frame = this.$frames.eq(frame),
   elements = this.config.elements,
   e, elementOptions,
   $found, $frameElements = $([]);

  for (e in elements) {
  elementOptions = elements[e];
  $found = $frame.find(e);
  $found.addClass("t-frame-element").data("tlrkAnimOptions", $.extend({}, this.defaults.defaultElementOptions, elementOptions ));
  $frameElements = $frameElements.add($found);
  }

  return $frameElements;
 },

 // returns jquery collection of elements that have to be faded out
 // i.e. elements on the same level as the animation elements
 // that doesn't contain other animation elements
 _getDisposeFrameElements: function(frame) {
  var $disposeElements = $([]),
   $frame = this.$frames.eq(frame),
   $elements = this._$elementsByFrame[frame];

  $elements.each(function(){
  var $t = $(this),
   $siblings = $t.siblings().not(".t-frame-element");

  $siblings.each(function(){
   var $t = $(this);
   // check if the node is not already marked and doesn't contains other frame elements
   if (!$t.hasClass("t-frame-dispose") && $t.find(".t-frame-element").length === 0) {
   $t.addClass("t-frame-dispose");
   $disposeElements = $disposeElements.add($t);
   }
  });

  });
  return $disposeElements;
 },

 // expose the internal animationIn/Out functions that are called for each element in the frame
 // two arguments are passed - the $element which have to be animated and the window width
 _animationIn: sweepIn,
 _animationOut: sweepOut

 }

 TlrkSlider.defaults = TlrkSlider.prototype.defaults;

 $.fn.tlrkSlider = function(options) {
 var otherArgs = Array.prototype.slice.call(arguments, 1);

 return this.each(function() {
  var $el = $(this),
   pluginData = $el.data("tlrkSlider");

  if (!pluginData) { // check if the slider is already attached
  pluginData = new TlrkSlider(this, options).init();
  $el.data("tlrkSlider", pluginData);
  return;
  }

  //change the options or call a method
  if (typeof options === "string") {

  // setting / getting option(s)
  if (options === "option") {

   if (typeof otherArgs[0] === "string" && typeof otherArgs[1] !== "undefined") { // set an option value
   pluginData.config[otherArgs[0]] = otherArgs[1]; 
   }

   if (typeof otherArgs[0] === "object") { // extend the config with new options
   pluginData.config = $.extend(pluginData.config, otherArgs[0]);
   }

  } else { // call a method?
   try {
   pluginData[options].apply(pluginData, otherArgs);
   } catch(ex) {
   throw "Error calling a plugin method (" + ex + ")";
   }
  }
  }
 });
 };

 window.TlrkSlider = TlrkSlider;

})( jQuery, window , document );

下面是页面调用的JS代码:

$(document).ready(function(){
 var $backgrounds = $(".header-content").find(".parallax-bg"),
  LAYER_OFFSET = 30,
  PRLX_SPEED = 1500,
  $slider;

 $slider = $("#slider").tlrkSlider({
 autoStart: true,
 animationStart: function(ev, slider, step){
  var max_steps = this.framesCount; 
  $backgrounds.each(function(idx, el){
  var pos = (step * (100 / max_steps)) + (LAYER_OFFSET * idx);
  $(this).animate({"backgroundPosition": pos + "% 0"}, PRLX_SPEED);
  });
 },
 elements: {
  "img": {delay: 10},
  "h2": {delay: 500},
  ".copy": {delay: 800},
  ".button": {delay: 1000}
 }
 });

 $(".header-content")
 .hover(
  function(){$(this).find(".slider-prev, .slider-next").show();},
  function(){$(this).find(".slider-prev, .slider-next").hide();}
 )
 .find(".slider-prev").click(function(){$slider.tlrkSlider("go", "prev"); return false; }).end()
 .find(".slider-next").click(function(){$slider.tlrkSlider("go", "next"); return false; });

});

希望本文对大家学习javascript程序设计有所帮助。

Javascript 相关文章推荐
IE与FireFox的兼容性问题分析
Apr 22 Javascript
精解window.setTimeout()&amp;window.setInterval()使用方式与参数传递问题!
Nov 23 Javascript
网站内容禁止复制和粘贴、另存为的js代码
Feb 26 Javascript
jQuery多个input求和的实现方法
Feb 12 Javascript
input点击后placeholder中的提示消息消失
Jan 15 Javascript
Bootstrap表格制作代码
Mar 17 Javascript
Vue侧滑菜单组件——DrawerLayout
Dec 18 Javascript
vue项目中用cdn优化的方法
Jan 03 Javascript
jquery实现Ajax请求的几种常见方式总结
May 28 jQuery
Vue 电商后台管理项目阶段性总结(推荐)
Aug 22 Javascript
Flexible.js可伸缩布局实现方法详解
Nov 13 Javascript
vue3+typeScript穿梭框的实现示例
Dec 29 Vue.js
JavaScript编程学习技巧汇总
Feb 21 #Javascript
Node.js开发者必须了解的4个JS要点
Feb 21 #Javascript
JSON简介以及用法汇总
Feb 21 #Javascript
javascript实现计时器的简单方法
Feb 21 #Javascript
JS中Eval解析JSON字符串的一个小问题
Feb 21 #Javascript
浏览器检测JS代码(兼容目前各大主流浏览器)
Feb 21 #Javascript
gameboy网页闯关游戏(riddle webgame)--仿微信聊天的前端页面设计和难点
Feb 21 #Javascript
You might like
PHP多线程抓取网页实现代码
2010/07/22 PHP
php调用google接口生成二维码示例
2014/04/28 PHP
php解析http获取的json字符串变量总是空白null
2015/03/02 PHP
PHP执行linux命令常用函数汇总
2016/02/02 PHP
利用php实现一周之内自动登录存储机制(cookie、session、localStorage)
2016/10/31 PHP
PHP时间类完整代码实例
2021/02/26 PHP
JS getMonth()日期函数的值域是0-11
2010/02/15 Javascript
返回上一页并自动刷新的JavaScript代码
2014/02/19 Javascript
ff chrome和ie下全局动态定位的异同及全局高度的取法
2014/06/30 Javascript
JavaScript常用脚本汇总(二)
2015/03/04 Javascript
JS简单获取客户端IP地址的方法【调用搜狐接口】
2016/09/05 Javascript
使用JS中的Replace()方法遇到的问题小结
2017/10/20 Javascript
node.js的exports、module.exports与ES6的export、export default深入详解
2017/10/26 Javascript
对Vue- 动态元素属性及v-bind和v-model的区别详解
2018/08/27 Javascript
微信小程序中的video视频实现 自定义播放按钮、封面图、视频封面上文案
2020/01/02 Javascript
html-webpack-plugin修改页面的title的方法
2020/06/18 Javascript
uniapp,微信小程序中使用 MQTT的问题
2020/07/11 Javascript
js实现删除json中指定的元素
2020/09/22 Javascript
解决Mint-ui 框架Popup和Datetime Picker组件滚动穿透的问题
2020/11/04 Javascript
[01:54]TI4西雅图DOTA2选手欢迎晚宴 现场报道
2014/07/08 DOTA
python抓取网页中的图片示例
2014/02/28 Python
Python的Tornado框架异步编程入门实例
2015/04/24 Python
Python使用base64模块进行二进制数据编码详解
2018/01/11 Python
python使用mitmproxy抓取浏览器请求的方法
2019/07/02 Python
对Python函数设计规范详解
2019/07/19 Python
pycharm实现猜数游戏
2020/12/07 Python
Myprotein加拿大官网:欧洲第一的运动营养品牌
2018/01/06 全球购物
纽约复古灵感的现代珠宝品牌:Lulu Frost
2018/03/03 全球购物
比利时香水网上商店:NOTINO
2018/03/28 全球购物
师德师风自我评价范文
2014/09/11 职场文书
个人自我剖析材料
2014/09/30 职场文书
领导班子“四风问题”“整改方案
2014/10/02 职场文书
事业单位年度考核个人总结
2015/02/12 职场文书
幼儿教师辞职信范文
2015/03/02 职场文书
公路施工安全责任书
2015/05/08 职场文书
SQL中去除重复数据的几种方法汇总(窗口函数对数据去重)
2023/05/08 MySQL