simple.slide.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413
  1. /*
  2. *
  3. * IE 9+ jQuery 1.8.3
  4. * QQ:109131145
  5. *
  6. * */
  7. var _LOOK_INDEX = 0;//设置一个全局变量
  8. (function ($) {
  9. $.fn.simpleSlide = function (options) {
  10. //获取当前ID
  11. var _i = _LOOK_INDEX;
  12. //获取所有this
  13. var _THIS = $(this);
  14. //属性
  15. var _defaults = {
  16. "opacity": 0.8,
  17. "windowAction": "fadeIn",
  18. "imageAction": "fadeIn",
  19. "loadingImage": "/overseas/img/1.gif"
  20. };
  21. var _OPTIONS = $.extend(_defaults, options);
  22. //获取属性
  23. var _ATTR = _OPTIONS;
  24. //存储图片地址的数组
  25. var _ALL_IMG_URL = [];
  26. var _I = 0;
  27. //遍历把图片地址存储到数组里
  28. _THIS.each(function (i) {
  29. var _OBJ = $(this);
  30. _OBJ.attr("i") == undefined ? _ALL_IMG_URL[i] = undefined : _ALL_IMG_URL[i] = _OBJ.attr("i");
  31. if (_OBJ.attr("i") == undefined) {
  32. _I++;
  33. }
  34. });
  35. //判断图片URL的数量
  36. if (_I == _THIS.size()) {
  37. return false;//没有图片则结束函数
  38. }
  39. //返回一个非undefined 的 URL
  40. function _GET_URL() {
  41. for (var i = 0; i < _ALL_IMG_URL.length; i++) {
  42. if (_ALL_IMG_URL[i] != undefined) {
  43. return i;
  44. }
  45. }
  46. }
  47. _SET_WINDOWS();//初始化添加元素
  48. //获取背景元素
  49. var _LOOK_BACK = $(".LookPicture_Background").eq(_i);
  50. //设置背景透明度
  51. _LOOK_BACK.fadeTo(0, _ATTR.opacity);
  52. //获取主窗口元素
  53. var _LOOK_OBJ = $("#LookPicture_" + _i);
  54. //获取上下页按钮元素
  55. var _LOOK_BEFORE = _LOOK_OBJ.find(".Look_before");
  56. var _LOOK_NEXT = _LOOK_OBJ.find(".Look_next");
  57. _THIS.css("cursor", "pointer");
  58. //点击事件
  59. _THIS.on("click", function () {
  60. $(document.body).addClass("none");
  61. //获取当前的点击元素的索引
  62. var _IMG_INDEX = _THIS.index($(this));
  63. //如果当前元素不存在 i 元素 则返回一个一个正确的URL
  64. _IMG_INDEX = _ALL_IMG_URL[_IMG_INDEX] == undefined ? _GET_URL() : _IMG_INDEX;
  65. //显示背景
  66. _LOOK_BACK.addClass("Look_Open");
  67. //显示主窗体
  68. _LOOK_OBJ.addClass("Look_Open");
  69. _LOOK_OBJ.find(".Look_img").removeClass("Look_Show");
  70. _LOOK_OBJ.find(".Look_img").eq(_IMG_INDEX).addClass("Look_Show");
  71. _LOADING(_IMG_INDEX);
  72. //调整尺寸
  73. _LOOK_SIZE();
  74. });
  75. _LOOK_OBJ.bind('mousewheel', function (event, delta) {
  76. var dir = delta > 0 ? 'Up' : 'Down';
  77. if(dir=='Up'){
  78. _LOOK_BEFORE.click();
  79. }else{
  80. _LOOK_NEXT.click();
  81. }
  82. //console.log(delta);
  83. });
  84. //关闭事件
  85. _LOOK_OBJ.find(".Look_Close").click(function () {
  86. //关闭背景
  87. _LOOK_BACK.removeClass("Look_Open");
  88. //关闭主窗体
  89. _LOOK_OBJ.removeClass("Look_Open");
  90. $(document.body).removeClass("none");
  91. });
  92. //上一页按钮点击
  93. _LOOK_BEFORE.click(function () {
  94. //获取当前显示图片的索引
  95. var _ID = _LOOK_OBJ.find(".Look_img").index(_LOOK_OBJ.find(".Look_Show"));
  96. _GET_ZQ_ID(_ID, 0);
  97. });
  98. //下一页按钮点击
  99. _LOOK_NEXT.click(function () {
  100. //获取当前显示图片的索引
  101. var _ID = _LOOK_OBJ.find(".Look_img").index(_LOOK_OBJ.find(".Look_Show"));
  102. _GET_ZQ_ID(_ID, 1);
  103. });
  104. function _GET_ZQ_ID(id, num) {
  105. //1 加
  106. if (num == "1") {
  107. id++;
  108. if (id >= _ALL_IMG_URL.length) {
  109. id = 0;
  110. }
  111. _LOOK_OBJ.find(".Look_img").removeClass("Look_Show");
  112. _LOOK_OBJ.find(".Look_img").eq(id).addClass("Look_Show");
  113. } else {
  114. id--;
  115. if (id < 0) {
  116. id = _ALL_IMG_URL.length - 1;
  117. }
  118. _LOOK_OBJ.find(".Look_img").removeClass("Look_Show");
  119. _LOOK_OBJ.find(".Look_img").eq(id).addClass("Look_Show");
  120. }
  121. _LOADING(id);
  122. _LOOK_SIZE();
  123. }
  124. function _LOADING(i) {
  125. var _showImg = _LOOK_OBJ.find(".Look_img").eq(i);
  126. var src = _showImg.attr('src');
  127. var iSrc = _showImg.attr('iSrc');
  128. src == _ATTR.loadingImage ? _LOADING_IMAGE(_showImg, iSrc) : !!0;
  129. _LOOK_SIZE();
  130. }
  131. function _LOADING_IMAGE(Img, src) {
  132. var img = new Image();
  133. $(img).load(function () {
  134. Img.attr('src', src);
  135. _LOOK_SIZE();
  136. }).error(function () {
  137. console.log(src, ' - Url Error')
  138. }).attr("src", src);
  139. }
  140. //设置窗口
  141. function _SET_WINDOWS() {
  142. //添加背景
  143. $(document.body).append("<div class='LookPicture_Background'></div>");
  144. //添加主窗口
  145. $(document.body).append('<div class="LookPicture animated ' + _ATTR.windowAction + '" id="LookPicture_' + _i + '"></div>');
  146. //添加关闭按钮
  147. $("#LookPicture_" + _i).append('<span class="Look_Close"></span>');
  148. //循环添加图片
  149. for (var i = 0; i < _ALL_IMG_URL.length; i++) {
  150. $("#LookPicture_" + _i).append('<img alt="No (i) attribute or URL error" class="Look_img animated ' + _ATTR.imageAction + '" src="' + _ATTR.loadingImage + '" iSrc="' + _ALL_IMG_URL[i] + '"/>');
  151. }
  152. //添加上一页按钮
  153. $("#LookPicture_" + _i).append('<span class="Look_before"></span>');
  154. //添加下一页按钮
  155. $("#LookPicture_" + _i).append('<span class="Look_next"></span>');
  156. }
  157. //累加++
  158. _LOOK_INDEX++;
  159. };
  160. })(jQuery);
  161. //全局函数
  162. function _LOOK_SIZE() {
  163. $(".Look_Show").each(function (i) {
  164. var _wi = $(this).width();
  165. var _he = $(this).height();
  166. $(this).css({
  167. "margin-top": -(_he / 2) + "px",
  168. "margin-left": -(_wi / 2) + "px"
  169. });
  170. });
  171. }
  172. $(window).resize(function () {
  173. _LOOK_SIZE();
  174. });
  175. $(function () {
  176. //初始化
  177. _LOOK_SIZE();
  178. });
  179. /* 滚轮封装 */
  180. (function (factory) {
  181. if ( typeof define === 'function' && define.amd ) {
  182. // AMD. Register as an anonymous module.
  183. define(['jquery'], factory);
  184. } else if (typeof exports === 'object') {
  185. // Node/CommonJS style for Browserify
  186. module.exports = factory;
  187. } else {
  188. // Browser globals
  189. factory(jQuery);
  190. }
  191. }(function ($) {
  192. var toFix = ['wheel', 'mousewheel', 'DOMMouseScroll', 'MozMousePixelScroll'],
  193. toBind = ( 'onwheel' in document || document.documentMode >= 9 ) ?
  194. ['wheel'] : ['mousewheel', 'DomMouseScroll', 'MozMousePixelScroll'],
  195. slice = Array.prototype.slice,
  196. nullLowestDeltaTimeout, lowestDelta;
  197. if ( $.event.fixHooks ) {
  198. for ( var i = toFix.length; i; ) {
  199. $.event.fixHooks[ toFix[--i] ] = $.event.mouseHooks;
  200. }
  201. }
  202. var special = $.event.special.mousewheel = {
  203. version: '3.1.9',
  204. setup: function() {
  205. if ( this.addEventListener ) {
  206. for ( var i = toBind.length; i; ) {
  207. this.addEventListener( toBind[--i], handler, false );
  208. }
  209. } else {
  210. this.onmousewheel = handler;
  211. }
  212. // Store the line height and page height for this particular element
  213. $.data(this, 'mousewheel-line-height', special.getLineHeight(this));
  214. $.data(this, 'mousewheel-page-height', special.getPageHeight(this));
  215. },
  216. teardown: function() {
  217. if ( this.removeEventListener ) {
  218. for ( var i = toBind.length; i; ) {
  219. this.removeEventListener( toBind[--i], handler, false );
  220. }
  221. } else {
  222. this.onmousewheel = null;
  223. }
  224. },
  225. getLineHeight: function(elem) {
  226. return parseInt($(elem)['offsetParent' in $.fn ? 'offsetParent' : 'parent']().css('fontSize'), 10);
  227. },
  228. getPageHeight: function(elem) {
  229. return $(elem).height();
  230. },
  231. settings: {
  232. adjustOldDeltas: true
  233. }
  234. };
  235. $.fn.extend({
  236. mousewheel: function(fn) {
  237. return fn ? this.bind('mousewheel', fn) : this.trigger('mousewheel');
  238. },
  239. unmousewheel: function(fn) {
  240. return this.unbind('mousewheel', fn);
  241. }
  242. });
  243. function handler(event) {
  244. var orgEvent = event || window.event,
  245. args = slice.call(arguments, 1),
  246. delta = 0,
  247. deltaX = 0,
  248. deltaY = 0,
  249. absDelta = 0;
  250. event = $.event.fix(orgEvent);
  251. event.type = 'mousewheel';
  252. // Old school scrollwheel delta
  253. if ( 'detail' in orgEvent ) { deltaY = orgEvent.detail * -1; }
  254. if ( 'wheelDelta' in orgEvent ) { deltaY = orgEvent.wheelDelta; }
  255. if ( 'wheelDeltaY' in orgEvent ) { deltaY = orgEvent.wheelDeltaY; }
  256. if ( 'wheelDeltaX' in orgEvent ) { deltaX = orgEvent.wheelDeltaX * -1; }
  257. // Firefox < 17 horizontal scrolling related to DOMMouseScroll event
  258. if ( 'axis' in orgEvent && orgEvent.axis === orgEvent.HORIZONTAL_AXIS ) {
  259. deltaX = deltaY * -1;
  260. deltaY = 0;
  261. }
  262. // Set delta to be deltaY or deltaX if deltaY is 0 for backwards compatabilitiy
  263. delta = deltaY === 0 ? deltaX : deltaY;
  264. // New school wheel delta (wheel event)
  265. if ( 'deltaY' in orgEvent ) {
  266. deltaY = orgEvent.deltaY * -1;
  267. delta = deltaY;
  268. }
  269. if ( 'deltaX' in orgEvent ) {
  270. deltaX = orgEvent.deltaX;
  271. if ( deltaY === 0 ) { delta = deltaX * -1; }
  272. }
  273. // No change actually happened, no reason to go any further
  274. if ( deltaY === 0 && deltaX === 0 ) { return; }
  275. // Need to convert lines and pages to pixels if we aren't already in pixels
  276. // There are three delta modes:
  277. // * deltaMode 0 is by pixels, nothing to do
  278. // * deltaMode 1 is by lines
  279. // * deltaMode 2 is by pages
  280. if ( orgEvent.deltaMode === 1 ) {
  281. var lineHeight = $.data(this, 'mousewheel-line-height');
  282. delta *= lineHeight;
  283. deltaY *= lineHeight;
  284. deltaX *= lineHeight;
  285. } else if ( orgEvent.deltaMode === 2 ) {
  286. var pageHeight = $.data(this, 'mousewheel-page-height');
  287. delta *= pageHeight;
  288. deltaY *= pageHeight;
  289. deltaX *= pageHeight;
  290. }
  291. // Store lowest absolute delta to normalize the delta values
  292. absDelta = Math.max( Math.abs(deltaY), Math.abs(deltaX) );
  293. if ( !lowestDelta || absDelta < lowestDelta ) {
  294. lowestDelta = absDelta;
  295. // Adjust older deltas if necessary
  296. if ( shouldAdjustOldDeltas(orgEvent, absDelta) ) {
  297. lowestDelta /= 40;
  298. }
  299. }
  300. // Adjust older deltas if necessary
  301. if ( shouldAdjustOldDeltas(orgEvent, absDelta) ) {
  302. // Divide all the things by 40!
  303. delta /= 40;
  304. deltaX /= 40;
  305. deltaY /= 40;
  306. }
  307. // Get a whole, normalized value for the deltas
  308. delta = Math[ delta >= 1 ? 'floor' : 'ceil' ](delta / lowestDelta);
  309. deltaX = Math[ deltaX >= 1 ? 'floor' : 'ceil' ](deltaX / lowestDelta);
  310. deltaY = Math[ deltaY >= 1 ? 'floor' : 'ceil' ](deltaY / lowestDelta);
  311. // Add information to the event object
  312. event.deltaX = deltaX;
  313. event.deltaY = deltaY;
  314. event.deltaFactor = lowestDelta;
  315. // Go ahead and set deltaMode to 0 since we converted to pixels
  316. // Although this is a little odd since we overwrite the deltaX/Y
  317. // properties with normalized deltas.
  318. event.deltaMode = 0;
  319. // Add event and delta to the front of the arguments
  320. args.unshift(event, delta, deltaX, deltaY);
  321. // Clearout lowestDelta after sometime to better
  322. // handle multiple device types that give different
  323. // a different lowestDelta
  324. // Ex: trackpad = 3 and mouse wheel = 120
  325. if (nullLowestDeltaTimeout) { clearTimeout(nullLowestDeltaTimeout); }
  326. nullLowestDeltaTimeout = setTimeout(nullLowestDelta, 200);
  327. return ($.event.dispatch || $.event.handle).apply(this, args);
  328. }
  329. function nullLowestDelta() {
  330. lowestDelta = null;
  331. }
  332. function shouldAdjustOldDeltas(orgEvent, absDelta) {
  333. // If this is an older event and the delta is divisable by 120,
  334. // then we are assuming that the browser is treating this as an
  335. // older mouse wheel event and that we should divide the deltas
  336. // by 40 to try and get a more usable deltaFactor.
  337. // Side note, this actually impacts the reported scroll distance
  338. // in older browsers and can cause scrolling to be slower than native.
  339. // Turn this off by setting $.event.special.mousewheel.settings.adjustOldDeltas to false.
  340. return special.settings.adjustOldDeltas && orgEvent.type === 'mousewheel' && absDelta % 120 === 0;
  341. }
  342. }));