common.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. $(document).ready(function () {
  2. $(".layui-side .layui-nav-item").not('.layui-nav-itemspec').mouseenter(function () {
  3. if ($(".layui-side-menu").hasClass('layui-sideact')) {
  4. $(this).addClass('layui-nav-itemact')
  5. }
  6. })
  7. $(".layui-side .layui-nav-item").not('.layui-nav-itemspec').mouseleave(function () {
  8. if ($(".layui-side-menu").hasClass('layui-sideact')) {
  9. $(".layui-sideact .layui-nav-item").not('.layui-nav-itemspec').removeClass('layui-nav-itemact')
  10. }
  11. })
  12. $(".layui-nav-itemspec").find('.layui-icon').on("click", function () {
  13. if ($(".layui-side-menu").hasClass('layui-sideact')) {
  14. $(".layui-side-menu").removeClass('layui-sideact')
  15. $(".layui-body").removeClass('layui-bodyact')
  16. } else {
  17. $(".layui-side-menu").addClass('layui-sideact')
  18. $(".layui-body").addClass('layui-bodyact')
  19. }
  20. })
  21. var urlStr = GetUrlRelativePath()
  22. $(".layui-nav-tree .layui-nav-item .layui-nav-child a").each(function(index,item) {
  23. if($(item).attr('href') == urlStr) {
  24. $(item).addClass('active')
  25. $(item).closest('.layui-nav-item').addClass('layui-nav-itemed')
  26. }
  27. })
  28. })
  29. //获取相对路径
  30. function GetUrlRelativePath() {
  31.   var url = document.location.toString();
  32.   var arrUrl = url.split("//");
  33.   var start = arrUrl[1].indexOf("/");
  34.   var relUrl = arrUrl[1].substring(start);
  35.   if (relUrl.indexOf("?") != -1) {
  36.  relUrl = relUrl.split("?")[0];
  37.   }
  38.   return relUrl;
  39. }
  40. // 时间标准格式的转换
  41. function isZero(m){
  42. return m<10?'0'+m:m
  43. }
  44. function formatDate(timestamp) {
  45. var time = new Date(timestamp);
  46. var y = time.getFullYear();
  47. var m = time.getMonth()+1;
  48. var d = time.getDate();
  49. var h = time.getHours();
  50. var mm = time.getMinutes();
  51. var s = time.getSeconds();
  52. return y+'-'+isZero(m)+'-'+isZero(d)+' '+isZero(h)+':'+isZero(mm)+':'+isZero(s);
  53. }
  54. //只能输入两位并且保留两位小数
  55. function clearNoNum(obj){
  56. obj.value = obj.value.replace(/[^\d.]/g,""); //清除“数字”和“.”以外的字符
  57. obj.value = obj.value.replace(/\.{2,}/g,"."); //只保留第一个. 清除多余的
  58. obj.value = obj.value.replace(".","$#$").replace(/\./g,"").replace("$#$",".");
  59. obj.value = obj.value.replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3');//只能输入两个小数
  60. if(obj.value.indexOf(".")< 0 && obj.value !=""){//以上已经过滤,此处控制的是如果没有小数点,首位不能为类似于 01、02的金额
  61. obj.value= parseFloat(obj.value);
  62. }
  63. }
  64. //只能输入正整数或零
  65. function positive(obj){
  66. var regs = /^(0|[1-9][0-9]*)$/;
  67. if(regs.test(obj.value)) {
  68. obj.value = parseInt(obj.value)
  69. }else{
  70. obj.value = ''
  71. }
  72. }
  73. // 获取地址栏的参数
  74. function getUrlParam(name){
  75. var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)");
  76. var r = window.location.search.substr(1).match(reg);
  77. if (r!=null) return unescape(r[2]); return null;
  78. }
  79. /**
  80. * 图片压缩,默认同比例压缩
  81. * @param {Object} path
  82. * pc端传入的路径可以为相对路径,但是在移动端上必须传入的路径是照相图片储存的绝对路径
  83. * @param {Object} obj
  84. * obj 对象 有 width, height, quality(0-1)
  85. * @param {Object} callback
  86. * 回调函数有一个参数,base64的字符串数据
  87. */
  88. function dealImage(path, obj, callback) {
  89. var img = new Image();
  90. img.src = path;
  91. img.onload = function () {
  92. var that = this;
  93. // 默认按比例压缩
  94. var w = that.width,
  95. h = that.height,
  96. scale = w / h;
  97. w = obj.width || w;
  98. h = obj.height || (w / scale);
  99. var quality = 0.7; // 默认图片质量为0.7
  100. //生成canvas
  101. var canvas = document.createElement('canvas');
  102. var ctx = canvas.getContext('2d');
  103. // 创建属性节点
  104. var anw = document.createAttribute("width");
  105. anw.nodeValue = w;
  106. var anh = document.createAttribute("height");
  107. anh.nodeValue = h;
  108. canvas.setAttributeNode(anw);
  109. canvas.setAttributeNode(anh);
  110. ctx.drawImage(that, 0, 0, w, h);
  111. // 图像质量
  112. if (obj.quality && obj.quality <= 1 && obj.quality > 0) {
  113. quality = obj.quality;
  114. }
  115. // quality值越小,所绘制出的图像越模糊
  116. var base64 = canvas.toDataURL('image/jpeg', quality);
  117. // 回调函数返回base64的值
  118. callback(base64);
  119. }
  120. }
  121. // 修改个人信息
  122. function showPop() {
  123. layer.open({
  124. type: 1,
  125. title: "编辑个人信息",
  126. area: ['420px', '220px'],
  127. shade: 0,
  128. content: $("#popUpdate"),//引用的弹出层的页面层的方式加载修改界面表单
  129. success: function (res) {
  130. if(res.code == 0) {
  131. layer.msg(res.message,{icon: 6},function() {
  132. layer.closeAll()
  133. });
  134. }else{
  135. layer.msg("网络错误,请稍后再试", {icon: 5},function() {
  136. layer.closeAll()
  137. });
  138. }
  139. },
  140. cancel: function(){ //点击取消
  141. $("#popUpdate").hide()
  142. layer.closeAll()
  143. }
  144. });
  145. }
  146. layui.use('form', function () {
  147. var form = layui.form;
  148. form.on('submit(modebtn)', function (data) {
  149. var uregs = /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{6,12}$/
  150. if(data.field.nickname.length < 4 || data.field.nickname.length > 12) {
  151. layer.tips('请输入正确的昵称格式',$("#modenickname"),{
  152. tips: [3, '#0FA6D8']
  153. });
  154. $("#nickname").focus();
  155. return false;
  156. }
  157. if(!uregs.test(data.field.password)) {
  158. layer.tips('请输入正确的密码格式',$("#modepassword"),{
  159. tips: [3, '#0FA6D8']
  160. });
  161. $("#password").focus();
  162. return false;
  163. }
  164. $.ajax({
  165. type:'post',
  166. url:'', //修改个人信息的接口
  167. dataType:'json',
  168. data:JSON.stringify(data.field),
  169. success:function(res) {
  170. if(res.code == 0) {
  171. layer.msg('创建成功',{icon: 6});
  172. }else{
  173. layer.msg("网络错误,请稍后再试", {icon: 5});
  174. }
  175. }
  176. })
  177. return false;
  178. });
  179. });
  180. //中奖号码变红
  181. function getRepeat(arr1, arr2) {
  182. if(arr1 && arr1.length>0 && arr2 && arr2.length>0) {
  183. for (let i = 0; i < arr2.length; i++) {
  184. arr2[i] = arr2[i].indexOf('+')>-1?arr2[i].replace('+',''):arr2[i]
  185. for (let j = 0; j < arr1.length; j++) {
  186. arr1[j] = arr1[j].indexOf('+')>-1?arr1[j].replace('+',''):arr1[j]
  187. if(arr1[j] === arr2[i]){
  188. arr1[j] = ':'+(arr1[j].indexOf('+')>-1?arr1[j].replace('+',''):arr1[j])
  189. }
  190. }
  191. }
  192. }
  193. return arr1;
  194. }