common.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  1. //loading
  2. function loading() {
  3. $("body").append('<div class="loading"></div>');
  4. }
  5. function loadingStop() {
  6. $(".loading").remove();
  7. }
  8. //弹窗
  9. function fixedTipShow(content) {
  10. $("body").append(
  11. '<div class="fixedTip">' +
  12. ' <div class="aui-content">' +
  13. ' <div class="aui-row aui-padded-10 fixedTip-content aui-font-size-14">' +
  14. content +
  15. ' </div>' +
  16. ' <div class="aui-row aui-padded-10 aui-text-center aui-text-danger aui-border-t fixedTip-btn" onclick="fixedTipHide()">' +
  17. ' 关闭' +
  18. ' </div>' +
  19. ' </div>' +
  20. '</div>'
  21. )
  22. if($(".fixedTip .aui-content").height() <= $(window).height()) {
  23. $(".fixedTip .aui-content").css("margin-top", ($(window).height() - $(".fixedTip .aui-content").height()) / 2);
  24. } else {
  25. $(".fixedTip .aui-content").css({
  26. "height": $(window).height() - 40,
  27. "margin-top": "20px"
  28. }).find(".fixedTip-content").height($(window).height() - $(".fixedTip-btn").height() - 80);
  29. }
  30. }
  31. //底部弹窗
  32. function bottomTip(content) {
  33. $("body").append(
  34. '<div class="bottomTip aui-text-white">' +
  35. content +
  36. '</div>'
  37. )
  38. $(".bottomTip").animate({
  39. bottom: "50px"
  40. }, 249);
  41. setTimeout(function() {
  42. $(".bottomTip").animate({
  43. bottom: "-150px"
  44. }, 249);
  45. }, 3249);
  46. }
  47. //图片点击放大
  48. function photoSwiper() {
  49. // 控件引入文件
  50. $("head").append('<script src="../../script/photoswipe.min.js"></script>' +
  51. '<script src="../../script/photoswipe-ui-default.min.js"></script>' +
  52. '<link rel="stylesheet" type="text/css" href="../../css/photoswipe.css" />' +
  53. '<link rel="stylesheet" type="text/css" href="../../css/default-skin/default-skin.css" />'
  54. );
  55. // 控件弹窗
  56. $("body").append(
  57. '<div class="pswp" tabindex="-1" role="dialog" aria-hidden="true">' +
  58. ' <div class="pswp__bg"></div>' +
  59. ' <div class="pswp__scroll-wrap">' +
  60. ' <div class="pswp__container">' +
  61. ' <div class="pswp__item"></div>' +
  62. ' <div class="pswp__item"></div>' +
  63. ' <div class="pswp__item"></div>' +
  64. ' </div>' +
  65. ' <div class="pswp__ui pswp__ui--hidden">' +
  66. ' <div class="pswp__top-bar">' +
  67. ' <div class="pswp__counter"></div>' +
  68. ' <button class="pswp__button pswp__button--close" title="Close (Esc)"></button>' +
  69. ' <div class="pswp__preloader">' +
  70. ' <div class="pswp__preloader__icn">' +
  71. ' <div class="pswp__preloader__cut">' +
  72. ' <div class="pswp__preloader__donut"></div>' +
  73. ' </div>' +
  74. ' </div>' +
  75. ' </div>' +
  76. ' </div>' +
  77. ' <div class="pswp__share-modal pswp__share-modal--hidden pswp__single-tap">' +
  78. ' <div class="pswp__share-tooltip"></div>' +
  79. ' </div>' +
  80. ' <button class="pswp__button pswp__button--arrow--left" title="Previous (arrow left)"></button>' +
  81. ' <button class="pswp__button pswp__button--arrow--right" title="Next (arrow right)"></button>' +
  82. ' <div class="pswp__caption">' +
  83. ' <div class="pswp__caption__center"></div>' +
  84. ' </div>' +
  85. ' </div>' +
  86. ' </div>' +
  87. '</div>'
  88. );
  89. // 给b或div加href值
  90. for(var i = 0; i < $(".photoSwiper-img-box figure").length; i++) {
  91. $(".photoSwiper-img-box figure").eq(i).find("b").attr("href", $(".photoSwiper-img-box figure").eq(i).find("img").attr('src'));
  92. $(".photoSwiper-img-box figure").eq(i).find("div").attr("href", $(".photoSwiper-img-box figure").eq(i).find("img").attr('src'));
  93. }
  94. var initPhotoSwipeFromDOM = function(gallerySelector) {
  95. var parseThumbnailElements = function(el) {
  96. var thumbElements = el.childNodes,
  97. numNodes = thumbElements.length,
  98. items = [],
  99. figureEl,
  100. linkEl,
  101. size,
  102. item;
  103. for(var i = 0; i < numNodes; i++) {
  104. figureEl = thumbElements[i];
  105. if(figureEl.nodeType !== 1) {
  106. continue;
  107. }
  108. linkEl = figureEl.children[0];
  109. size = linkEl.getAttribute('data-size').split('x');
  110. item = {
  111. src: linkEl.getAttribute('href'),
  112. w: parseInt(size[0], 10),
  113. h: parseInt(size[1], 10)
  114. };
  115. if(figureEl.children.length > 1) {
  116. item.title = figureEl.children[1].innerHTML;
  117. }
  118. if(linkEl.children.length > 0) {
  119. item.msrc = linkEl.children[0].getAttribute('src');
  120. }
  121. item.el = figureEl;
  122. items.push(item);
  123. }
  124. return items;
  125. };
  126. var closest = function closest(el, fn) {
  127. return el && (fn(el) ? el : closest(el.parentNode, fn));
  128. };
  129. var onThumbnailsClick = function(e) {
  130. e = e || window.event;
  131. e.preventDefault ? e.preventDefault() : e.returnValue = false;
  132. var eTarget = e.target || e.srcElement;
  133. var clickedListItem = closest(eTarget, function(el) {
  134. return(el.tagName && el.tagName.toUpperCase() === 'FIGURE');
  135. });
  136. if(!clickedListItem) {
  137. return;
  138. }
  139. var clickedGallery = clickedListItem.parentNode,
  140. childNodes = clickedListItem.parentNode.childNodes,
  141. numChildNodes = childNodes.length,
  142. nodeIndex = 0,
  143. index;
  144. for(var i = 0; i < numChildNodes; i++) {
  145. if(childNodes[i].nodeType !== 1) {
  146. continue;
  147. }
  148. if(childNodes[i] === clickedListItem) {
  149. index = nodeIndex;
  150. break;
  151. }
  152. nodeIndex++;
  153. }
  154. if(index >= 0) {
  155. openPhotoSwipe(index, clickedGallery);
  156. }
  157. return false;
  158. };
  159. var photoswipeParseHash = function() {
  160. var hash = window.location.hash.substring(1),
  161. params = {};
  162. if(hash.length < 5) {
  163. return params;
  164. }
  165. var vars = hash.split('&');
  166. for(var i = 0; i < vars.length; i++) {
  167. if(!vars[i]) {
  168. continue;
  169. }
  170. var pair = vars[i].split('=');
  171. if(pair.length < 2) {
  172. continue;
  173. }
  174. params[pair[0]] = pair[1];
  175. }
  176. if(params.gid) {
  177. params.gid = parseInt(params.gid, 10);
  178. }
  179. return params;
  180. };
  181. var openPhotoSwipe = function(index, galleryElement, disableAnimation, fromURL) {
  182. var pswpElement = document.querySelectorAll('.pswp')[0],
  183. gallery,
  184. options,
  185. items;
  186. items = parseThumbnailElements(galleryElement);
  187. options = {
  188. galleryUID: galleryElement.getAttribute('data-pswp-uid'),
  189. getThumbBoundsFn: function(index) {
  190. var thumbnail = items[index].el.getElementsByTagName('img')[0], // find thumbnail
  191. pageYScroll = window.pageYOffset || document.documentElement.scrollTop,
  192. rect = thumbnail.getBoundingClientRect();
  193. return {
  194. x: rect.left,
  195. y: rect.top + pageYScroll,
  196. w: rect.width
  197. };
  198. }
  199. };
  200. if(fromURL) {
  201. if(options.galleryPIDs) {
  202. for(var j = 0; j < items.length; j++) {
  203. if(items[j].pid == index) {
  204. options.index = j;
  205. break;
  206. }
  207. }
  208. } else {
  209. options.index = parseInt(index, 10) - 1;
  210. }
  211. } else {
  212. options.index = parseInt(index, 10);
  213. }
  214. if(isNaN(options.index)) {
  215. return;
  216. }
  217. if(disableAnimation) {
  218. options.showAnimationDuration = 0;
  219. }
  220. gallery = new PhotoSwipe(pswpElement, PhotoSwipeUI_Default, items, options);
  221. gallery.init();
  222. };
  223. var galleryElements = document.querySelectorAll(gallerySelector);
  224. for(var i = 0, l = galleryElements.length; i < l; i++) {
  225. galleryElements[i].setAttribute('data-pswp-uid', i + 1);
  226. galleryElements[i].onclick = onThumbnailsClick;
  227. }
  228. var hashData = photoswipeParseHash();
  229. if(hashData.pid && hashData.gid) {
  230. openPhotoSwipe(hashData.pid, galleryElements[hashData.gid - 1], true, true);
  231. }
  232. };
  233. initPhotoSwipeFromDOM('.photoSwiper-img-box');
  234. }