main.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431
  1. var domanUrl = "http://" + window.location.host;
  2. var base_path = "http://w.iamberry.com/tooth";
  3. //var base_path = domanUrl+"/tooth";
  4. //ajax loading
  5. $(window).ajaxStart(function(){
  6. $(".covers").show();
  7. });
  8. $(window).ajaxStop(function(){
  9. $(".covers").hide();
  10. });
  11. mui.each(document.querySelectorAll('#footer-bar-tab .mui-tab-item'), function(index, el) {
  12. el.addEventListener('tap', function() {
  13. switch(index) {
  14. case 0:
  15. mui.openWindow({
  16. url: 'index.html'
  17. });
  18. break;
  19. case 1:
  20. mui.openWindow({
  21. url: 'pro-list.html'
  22. });
  23. break;
  24. case 2:
  25. mui.openWindow({
  26. url: 'shopping-cart.html'
  27. });
  28. break;
  29. case 3:
  30. mui.openWindow({
  31. url: 'my-center.html'
  32. });
  33. break;
  34. default:
  35. break;
  36. }
  37. }, false);
  38. });
  39. function time_before(t){
  40. var minute=1000*60;
  41. var hour=minute*60;
  42. var day=hour*24;
  43. var halfamonth=day*15;
  44. var month=day*30;
  45. var now=new Date().getTime();
  46. var diffValue=now-new Date().setTime(t);
  47. var monthC=diffValue/month;
  48. var weekC=diffValue/(7*day);
  49. var dayC=diffValue/day;
  50. var hourC=diffValue/hour;
  51. var minC=diffValue/minute;
  52. if(monthC>=1){
  53. result=""+parseInt(monthC)+"月前";
  54. }else if(weekC>=1){
  55. result=""+parseInt(weekC)+"周前";
  56. }else if(dayC>=1){
  57. result=""+parseInt(dayC)+"天前";
  58. }else if(hourC>=1){
  59. result=""+parseInt(hourC)+"小时前";
  60. }else if(minC>=2){
  61. result=""+parseInt(minC)+"分钟前";
  62. }else{
  63. result="刚刚";
  64. }
  65. return result;
  66. };
  67. //封装document.getElementById
  68. function dc(objectid) {
  69. if(document.getElementById && document.getElementById(objectid)) {
  70. return document.getElementById(objectid);// w3c dom
  71. } else if (document.all && document.all(objectid)) {
  72. return document.all(objectid);// msie 4 dom
  73. } else if (document.layers && document.layers[objectid]) {
  74. return document.layers[objectid];// nn 4 dom.. note: this won't find nested layers
  75. } else {
  76. return false;
  77. }
  78. };
  79. //生成随机字符,n长度
  80. function generateMixed(n) {
  81. var chars = ['0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'];
  82. var res = "";
  83. for(var i = 0; i < n ; i ++) {
  84. var id = Math.ceil(Math.random()*35);
  85. res += chars[id];
  86. }
  87. return res;
  88. }
  89. function getParam(paramName) {
  90. paramValue = "", isFound = !1;
  91. if(this.location.search.indexOf("?") == 0 && this.location.search.indexOf("=") > 1) {
  92. arrSource = unescape(this.location.search).substring(1, this.location.search.length).split("&"), i = 0;
  93. while(i < arrSource.length && !isFound) {
  94. arrSource[i].indexOf("=") > 0 && arrSource[i].split("=")[0].toLowerCase() == paramName.toLowerCase() && (paramValue = arrSource[i].split("=")[1], isFound = !0), i++
  95. }
  96. }
  97. return paramValue == "" && (paramValue = null), paramValue
  98. };
  99. function getQueryString(name) {
  100. var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
  101. var r = window.location.search.substr(1).match(reg);
  102. if (r != null) return unescape(r[2]); return null;
  103. }
  104. // 对Date的扩展,将 Date 转化为指定格式的String
  105. // 月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符,
  106. // 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字)
  107. // 例子:
  108. // (new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423
  109. // (new Date()).Format("yyyy-M-d h:m:s.S") ==> 2006-7-2 8:9:4.18
  110. Date.prototype.format = function(fmt)
  111. { //author: meizz
  112. var o = {
  113. "M+" : this.getMonth()+1, //月份
  114. "d+" : this.getDate(), //日
  115. "h+" : this.getHours(), //小时
  116. "m+" : this.getMinutes(), //分
  117. "s+" : this.getSeconds(), //秒
  118. "q+" : Math.floor((this.getMonth()+3)/3), //季度
  119. "S" : this.getMilliseconds() //毫秒
  120. };
  121. if(/(y+)/.test(fmt))
  122. fmt=fmt.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length));
  123. for(var k in o)
  124. if(new RegExp("("+ k +")").test(fmt))
  125. fmt = fmt.replace(RegExp.$1, (RegExp.$1.length==1) ? (o[k]) : (("00"+ o[k]).substr((""+ o[k]).length)));
  126. return fmt;
  127. }
  128. //计算月份差
  129. function getMonthNumber(date1,date2){
  130. //默认格式为"2010-01-01",根据自己需要改格式和方法
  131. var d1=date1.replaceAll("-",''),d2=date2.replaceAll("-",'');
  132. var year1 = d1.substring(0,4);
  133. var year2 = d2.substring(0,4);
  134. var month1 = d1.substring(6,4);
  135. var month2 = d2.substring(6,4);
  136. var len=parseInt((year2-year1)*12+(month2-month1));
  137. return len;
  138. }
  139. //替换所有要替换的文字
  140. String.prototype.replaceAll = function (str1,str2){
  141. var str = this;
  142. var result = str.replace(eval("/"+str1+"/gi"),str2);
  143. return result;
  144. }
  145. /**
  146. ** 加法函数,用来得到精确的加法结果
  147. ** 说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的加法结果。
  148. ** 调用:accAdd(arg1,arg2)
  149. ** 返回值:arg1加上arg2的精确结果
  150. **/
  151. function accAdd(arg1, arg2) {
  152. var r1, r2, m, c;
  153. try {
  154. r1 = arg1.toString().split(".")[1].length;
  155. }
  156. catch (e) {
  157. r1 = 0;
  158. }
  159. try {
  160. r2 = arg2.toString().split(".")[1].length;
  161. }
  162. catch (e) {
  163. r2 = 0;
  164. }
  165. c = Math.abs(r1 - r2);
  166. m = Math.pow(10, Math.max(r1, r2));
  167. if (c > 0) {
  168. var cm = Math.pow(10, c);
  169. if (r1 > r2) {
  170. arg1 = Number(arg1.toString().replace(".", ""));
  171. arg2 = Number(arg2.toString().replace(".", "")) * cm;
  172. } else {
  173. arg1 = Number(arg1.toString().replace(".", "")) * cm;
  174. arg2 = Number(arg2.toString().replace(".", ""));
  175. }
  176. } else {
  177. arg1 = Number(arg1.toString().replace(".", ""));
  178. arg2 = Number(arg2.toString().replace(".", ""));
  179. }
  180. return (arg1 + arg2) / m;
  181. }
  182. //给Number类型增加一个add方法,调用起来更加方便。
  183. Number.prototype.add = function (arg) {
  184. return accAdd(arg, this);
  185. };
  186. /**
  187. ** 减法函数,用来得到精确的减法结果
  188. ** 说明:javascript的减法结果会有误差,在两个浮点数相减的时候会比较明显。这个函数返回较为精确的减法结果。
  189. ** 调用:accSub(arg1,arg2)
  190. ** 返回值:arg1加上arg2的精确结果
  191. **/
  192. function accSub(arg1, arg2) {
  193. var r1, r2, m, n;
  194. try {
  195. r1 = arg1.toString().split(".")[1].length;
  196. }
  197. catch (e) {
  198. r1 = 0;
  199. }
  200. try {
  201. r2 = arg2.toString().split(".")[1].length;
  202. }
  203. catch (e) {
  204. r2 = 0;
  205. }
  206. m = Math.pow(10, Math.max(r1, r2)); //last modify by deeka //动态控制精度长度
  207. n = (r1 >= r2) ? r1 : r2;
  208. return ((arg1 * m - arg2 * m) / m).toFixed(n);
  209. }
  210. // 给Number类型增加一个mul方法,调用起来更加方便。
  211. Number.prototype.sub = function (arg) {
  212. return accSub(arg, this);
  213. };
  214. /**
  215. ** 除法函数,用来得到精确的除法结果
  216. ** 说明:javascript的除法结果会有误差,在两个浮点数相除的时候会比较明显。这个函数返回较为精确的除法结果。
  217. ** 调用:accDiv(arg1,arg2)
  218. ** 返回值:arg1除以arg2的精确结果
  219. **/
  220. function accDiv(arg1, arg2) {
  221. var t1 = 0, t2 = 0, r1, r2;
  222. try {
  223. t1 = arg1.toString().split(".")[1].length;
  224. }
  225. catch (e) {
  226. }
  227. try {
  228. t2 = arg2.toString().split(".")[1].length;
  229. }
  230. catch (e) {
  231. }
  232. with (Math) {
  233. r1 = Number((arg1 + "").replace(".", ""));
  234. r2 = Number((arg2 + "").replace(".", ""));
  235. return (r1 / r2) * pow(10, t2 - t1);
  236. }
  237. }
  238. //给Number类型增加一个div方法,调用起来更加方便。
  239. Number.prototype.div = function (arg) {
  240. return accDiv(this, arg);
  241. };
  242. /**
  243. ** 乘法函数,用来得到精确的乘法结果
  244. ** 说明:javascript的乘法结果会有误差,在两个浮点数相乘的时候会比较明显。这个函数返回较为精确的乘法结果。
  245. ** 调用:accMul(arg1,arg2)
  246. ** 返回值:arg1乘以 arg2的精确结果
  247. **/
  248. function accMul(arg1, arg2) {
  249. var m = 0, s1 = arg1.toString(), s2 = arg2.toString();
  250. try {
  251. m += s1.split(".")[1].length;
  252. }
  253. catch (e) {
  254. }
  255. try {
  256. m += s2.split(".")[1].length;
  257. }
  258. catch (e) {
  259. }
  260. return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m);
  261. }
  262. // 给Number类型增加一个mul方法,调用起来更加方便。
  263. Number.prototype.mul = function (arg) {
  264. return accMul(arg, this);
  265. };
  266. function formatDate(now) {
  267. now = new Date(now);
  268. var year=now.getFullYear();
  269. var month=now.getMonth()+1;
  270. if(month<10){
  271. month="0"+month;
  272. }
  273. var date=now.getDate();
  274. return year+"年"+month+"月"+date+"日";
  275. }
  276. function formatTime(msd) {
  277. var time = parseFloat(msd) /1000;
  278. if (null!= time &&""!= time) {
  279. if (time >60&& time <60*60) {
  280. time = parseInt(time /60.0) +"分";
  281. // time = parseInt(time /60.0) +"分钟"+ parseInt((parseFloat(time /60.0) -
  282. // parseInt(time /60.0)) *60) +"秒";
  283. }else if (time >=60*60&& time <60*60*24) {
  284. // time = parseInt(time /3600.0) +"小时"+ parseInt((parseFloat(time /3600.0) -
  285. // parseInt(time /3600.0)) *60) +"分钟"+
  286. // parseInt((parseFloat((parseFloat(time /3600.0) - parseInt(time /3600.0)) *60) -
  287. // parseInt((parseFloat(time /3600.0) - parseInt(time /3600.0)) *60)) *60) +"秒";
  288. time = parseInt(time /3600.0) +"时"+ parseInt((parseFloat(time /3600.0) -
  289. parseInt(time /3600.0)) *60) +"分";
  290. }else {
  291. time = parseInt(time) +"分";
  292. }
  293. }else{
  294. time = "0分";
  295. }
  296. return time;
  297. }
  298. function formatMinutes(msd) {
  299. // 参数msd (秒)
  300. var time = parseFloat(msd);
  301. if (null!= time && ""!= time) {
  302. if (time >0&& time <60*60) {
  303. time = parseInt(time /60.0) +"分";
  304. }else{
  305. time = parseInt(time /3600.0) +"时"+ parseInt((parseFloat(time /3600.0) -
  306. parseInt(time /3600.0)) *60) +"分";
  307. }
  308. }else{
  309. time = "0分";
  310. }
  311. return time;
  312. }
  313. function formatDay(now) {
  314. now = new Date(now);
  315. var month=now.getMonth()+1;
  316. if(month<10){
  317. month="0"+month;
  318. }
  319. var date=now.getDate();
  320. if(date<10){
  321. date="0"+date;
  322. }
  323. return month+"-"+date;
  324. }
  325. function formatDateFull(now) {
  326. now = new Date(now);
  327. var year=now.getFullYear();
  328. var month=now.getMonth()+1;
  329. if(month<10){
  330. month="0"+month;
  331. }
  332. var date=now.getDate();
  333. if(date<10){
  334. date="0"+date;
  335. }
  336. return year+"-"+month+"-"+date;
  337. }
  338. function formatDateMinute(now) {
  339. now = new Date(now);
  340. var year=now.getFullYear();
  341. var month=now.getMonth()+1;
  342. if(month<10){
  343. month="0"+month;
  344. }
  345. var date=now.getDate();
  346. if(date<10){
  347. date="0"+date;
  348. }
  349. var hour=now.getHours();
  350. if(hour<10){
  351. hour="0"+hour;
  352. }
  353. var Minute=now.getMinutes();
  354. if(Minute<10){
  355. Minute="0"+Minute;
  356. }
  357. return year+"-"+month+"-"+date+" "+hour+":"+Minute;
  358. }
  359. function int_for_time(obj){
  360. return obj+":00";
  361. }
  362. //替换指定传入参数的值,paramName为参数,replaceWith为新值
  363. function replaceParamVal(paramName,replaceWith) {
  364. var oUrl = this.location.href.toString();
  365. var re=eval('/('+ paramName+'=)([^&]*)/gi');
  366. var nUrl = oUrl.replace(re,paramName+'='+replaceWith);
  367. window.history.pushState({},0,nUrl);
  368. }
  369. function isEmptyObject(e) {
  370. var t;
  371. for (t in e)
  372. return !1;
  373. return !0
  374. }
  375. function gotoTop() {
  376. mui('.my-scroll-wrapper').scroll().scrollTo(0,0,500);//500毫秒滚动到顶
  377. //$(".mui-scroll").css({"transform":"translate3d(0px, 0px, 0px) translateZ(0px)","transition-duration":"100ms"});
  378. };
  379. function gotoBottom(){
  380. mui('.my-scroll-wrapper').scroll().scrollToBottom();//500毫秒滚动到底部
  381. }
  382. $(document).on('tap', '.go_pro_list', function() {
  383. var positions='';
  384. if(typeof($(this).attr("pos"))!="undefined"){
  385. positions=$(this).attr("pos");
  386. location.href="pro-list.html?pos="+positions;
  387. }else{
  388. location.href="pro-list.html";
  389. }
  390. });
  391. $(document).on('tap', '.icon-shouye', function() {
  392. location.href="index.html";
  393. });
  394. //回到顶部
  395. function gotoTop(acceleration, stime) {
  396. acceleration = acceleration || 0.1;
  397. stime = stime || 10;
  398. var x1 = 0,
  399. y1 = 0,
  400. x2 = 0,
  401. y2 = 0,
  402. x3 = 0,
  403. y3 = 0;
  404. if (document.documentElement) {
  405. x1 = document.documentElement.scrollLeft || 0;
  406. y1 = document.documentElement.scrollTop || 0;
  407. }
  408. if (document.body) {
  409. x2 = document.body.scrollLeft || 0;
  410. y2 = document.body.scrollTop || 0;
  411. }
  412. var x3 = window.scrollX || 0;
  413. var y3 = window.scrollY || 0;
  414. var x = Math.max(x1, Math.max(x2, x3));
  415. var y = Math.max(y1, Math.max(y2, y3));
  416. var speeding = 1 + acceleration;
  417. window.scrollTo(Math.floor(x / speeding), Math.floor(y / speeding));
  418. if (x > 0 || y > 0) {
  419. var run = "gotoTop(" + acceleration + ", " + stime + ")";
  420. window.setTimeout(run, stime);
  421. }
  422. }