You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
zhishifufei_php/public/static/plug/helper.js

338 lines
15 KiB

11 months ago
(function(global,factory){
typeof define == 'function' && define('helper',[],factory.bind(window));
global['$h'] = factory();
})(this,function(){
var $h = $h || {};
$h._errorMsgOptions = {offset: '80%',anim: 2,time:1200,shadeClose:true,shade:'0.1'};
$h.returnErrorMsg = function(msg,fn){
$h.pushMsg(msg,fn);
return false;
};
$h._loadIndex = null;
$h.pushMsg = function(msg,fn){
layer.msg(msg.toString(),$h._errorMsgOptions,fn);
};
$h.openImage=function(href){
return layer.open({
type: 1,
title: false,
closeBtn: 0,
shadeClose: true,
content: '<img src="' + href + '" style="display: block;width: 100%;" />'
});
};
$h.pushMsgOnceStatus = false;
$h.pushMsgOnce = function(msg,fn){
if($h.pushMsgOnceStatus) return ;
$h.pushMsgOnceStatus = true;
$h.pushMsg(msg,function(){
fn && fn();
$h.pushMsgOnceStatus = false;
});
}
$h.MsgStyle='<style id="_h_msg_style">#_h_msg_html_show{width: 2.3rem;height: 1.8rem;background-color: rgba(0,0,0,0.8);border-radius: 0.2rem;position: fixed;left:0; right:0; top:0; bottom:0;margin:auto;z-index: 10099;}#_h_msg_html_show .msg_title{color: #ffffff;text-align: center;padding: 0.2rem;}#_h_msg_html_show .msg_image{width: 0.8rem;height: 0.8rem;margin: 0 auto;display: inherit;margin-top: 0.2rem;}</style>';
$h.getMsgHthml=function (title,icon) {
var html='<div id="_h_msg_html_show">';
if(icon) html+='<img class="msg_image" src="/wap/first/zsff/images/msg_image/'+icon+'.png">';
if(title) html+='<p class="line1 msg_title">'+title+'</p>';
html+='</div>';
return html;
};
$h.showMsg=function(opt,successFn){
var $body = $('body'),title='',icon='error',endtime=1500,fn=null;
if(typeof opt=='object'){
title=opt.title || '';
icon=opt.icon || 'error';
endtime=opt.endtime || endtime;
fn=opt.success || fn;
}else if(typeof opt=='string'){
title=opt;
fn=successFn;
}
if(!$body.find('#_h_msg_style').length) $body.append(this.MsgStyle);
$body.append(this.getMsgHthml(title,icon));
setTimeout(function () {
$('#_h_msg_style').remove();
$('#_h_msg_html_show').remove();
fn && fn();
},endtime);
};
$h.OpenVideo=function(opt){
if(typeof opt=='string') opt={U:opt};
var url=opt.U || '';
if(!url) return;
$h.loadFFF();
$h.loadClear();
layer.open({
type: 2,
title: false,
area: [window.innerWidth+'px', '360px'],
shade: 0.8,
closeBtn: 0,
shadeClose: true,
content:url,
success:function () {
console.log(1);
}
});
}
/**
* 底部浮动框
* @param msg
*/
$h._promptStyle='<style id="_loading_bounce_style"> #_loading_bounce._prompt_hide{animation:down-hide .25s ease-in; animation-fill-mode: forwards; } #_loading_bounce{z-index: 998;position:fixed;bottom:0;background:#fff;width:100%;height:60px;box-shadow:0 1px 15px rgba(0,0,0,0.17);animation:up-show .25s ease-in}@keyframes up-show{0%{transform:translateY(60px)}100%{transform:translateY(0px)}}@keyframes down-hide{0%{transform:translateY(0px)}100%{transform:translateY(60px)}}#_loading_bounce ._double-container{height: 100%;display: table;position: absolute;width: 30%;left: 44%;} #_loading_bounce ._double-container .double-text{display: table-cell;vertical-align: middle;font-size: 12px;}.double-bounce1,.double-bounce2{width:50px;height:50px;border-radius:50%;background-color:#67CF22;opacity:.6;position:absolute;top:50%;margin-top:-25px;left:26%;-webkit-animation:bounce 2.0s infinite ease-in-out;-moz-animation:bounce 2.0s infinite ease-in-out;-o-animation:bounce 2.0s infinite ease-in-out;animation:bounce 2.0s infinite ease-in-out}.double-bounce2{-webkit-animation-delay:-1.0s;-moz-animation-delay:-1.0s;-o-animation-delay:-1.0s;animation-delay:-1.0s}@keyframes bounce{0%,100%{transform:scale(0.0)}50%{transform:scale(1.0)}}</style>';
$h._promptHtml = '<div id="_loading_bounce" class="_prompt_loading"><div class="mop-css-1 double-bounce"><div class="double-bounce1"></div><div class="double-bounce2"></div></div><div class="_double-container"><span class="double-text">请稍等片刻...</span></div></div>';
$h.prompt = function(msg){
var $body = $('body'),$prompt = $($h._promptHtml);
if(!$body.find('#_loading_bounce_style').length)
$body.append($h._promptStyle);
$prompt.find('.double-text').text(msg);
$body.append($prompt);
};
$h.promptClear = function() {
var that = $('._prompt_loading');
that.addClass('_prompt_hide');
setTimeout(function(){
that.remove();
},250)
};
$h.load = function(){
if($h._loadIndex !== null) $h.loadClear();
$h._loadIndex = layer.load(2, {shade: 0.3});
};
$h.loadFFF = function(){
if($h._loadIndex !== null) $h.loadClear();
$h._loadIndex = layer.load(1, {shade: [0.1,'#fff']});
};
$h.loadClear = function(){
setTimeout(function(){
layer.close($h._loadIndex);
},250);
};
$h.uploadFile = function (name,url,successFn,errorFn) {
$.ajaxFileUpload({
url: url,
type: 'post',
secureuri: false, //一般设置为false
fileElementId: name, // 上传文件的id、name属性名
dataType: 'json', //返回值类型,一般设置为json、application/json
success:successFn,
error: errorFn
});
};
$h.ajaxUploadFile = function (name,url,fnGroup) {
fnGroup.start && fnGroup.start();
$.ajaxFileUpload({
url: url,
type: 'POST',
secureuri: false, //一般设置为false
fileElementId: name, // 上传文件的id、name属性名
dataType: 'JSON', //返回值类型,一般设置为json、application/json
success:function(res,status){
fnGroup.success && fnGroup.success(res,status);
fnGroup.end && fnGroup.end(res,status);
// var fileInput = $("#"+name),html = fileInput.prop('outerHTML'),p = fileInput.parent();
// fileInput.remove();
// p.append(html);
},
error: function(res,status){
fnGroup.error && fnGroup.error(res,status);
fnGroup.end && fnGroup.end(res,status);
}
});
};
//除法函数,用来得到精确的除法结果
//说明:javascript的除法结果会有误差,在两个浮点数相除的时候会比较明显。这个函数返回较为精确的除法结果。
//调用:_h.Div(arg1,arg2)
//返回值:arg1除以arg2的精确结果
$h.div = function(arg1,arg2){
var t1=0,t2=0,r1,r2;
try{t1=arg1.toString().split(".")[1].length;}catch(e){}
try{t2=arg2.toString().split(".")[1].length;}catch(e){}
with(Math){
r1=Number(arg1.toString().replace(".",""));
r2=Number(arg2.toString().replace(".",""));
return (r1/r2)*pow(10,t2-t1);
}
};
//乘法函数,用来得到精确的乘法结果
//说明:javascript的乘法结果会有误差,在两个浮点数相乘的时候会比较明显。这个函数返回较为精确的乘法结果。
//调用:_h.Mul(arg1,arg2)
//返回值:arg1乘以arg2的精确结果
$h.Mul = function(arg1,arg2) {
var m=0,s1=arg1.toString(),s2=arg2.toString();
try{m+=s1.split(".")[1].length}catch(e){}
try{m+=s2.split(".")[1].length}catch(e){}
return Number(s1.replace(".","")) * Number(s2.replace(".","")) / Math.pow(10,m);
};
//加法函数,用来得到精确的加法结果
//说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的加法结果。
//调用:_h.Add(arg1,arg2)
//返回值:arg1加上arg2的精确结果
$h.Add = function(arg1,arg2){
var r1,r2,m;
try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
m=Math.pow(10,Math.max(r1,r2));
return (arg1*m+arg2*m)/m;
};
//加法函数,用来得到精确的减法结果
//说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的减法结果。
//调用:_h.Sub(arg1,arg2)
//返回值:arg1减去arg2的精确结果
$h.Sub = function(arg1,arg2){
var r1,r2,m,n;
try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
m=Math.pow(10,Math.max(r1,r2));
//动态控制精度长度
n=(r1>=r2)?r1:r2;
return ((arg1*m-arg2*m)/m).toFixed(n);
};
$h.cookie = function(key,val,time) {
if(val == undefined){
return _helper.getCookie(key);
}else if(val == null){
return _helper.delCookie(key);
}else{
return _helper.setCookie(key,val,time);
}
};
//操作cookie
$h.setCookie = function(key,val,time){//设置cookie方法
var date=new Date(); //获取当前时间
if(!time) time = 1; //将date设置为n天以后的时间
date.setTime(date.getTime()+time*24*3600*1000); //格式化为cookie识别的时间
document.cookie=key + "=" + val +";expires="+date.toGMTString(); //设置cookie
};
$h.getCookie = function(key) {//获取cookie方法
/*获取cookie参数*/
var getCookie = document.cookie.replace(/;[ ]/g, ";"); //获取cookie,并且将获得的cookie格式化,去掉空格字符
var arrCookie = getCookie.split(";"); //将获得的cookie以"分号"为标识 将cookie保存到arrCookie的数组中
var tips; //声明变量tips
for (var i = 0; i < arrCookie.length; i++) { //使用for循环查找cookie中的tips变量
var arr = arrCookie[i].split("="); //将单条cookie用"等号"为标识,将单条cookie保存为arr数组
if (key == arr[0]) { //匹配变量名称,其中arr[0]是指的cookie名称,如果该条变量为tips则执行判断语句中的赋值操作
tips = arr[1]; //将cookie的值赋给变量tips
break; //终止for循环遍历
}
}
return tips;
};
$h.delCookie = function(key){ //删除cookie方法
var date = new Date(); //获取当前时间
date.setTime(date.getTime()-10000); //将date设置为过去的时间
document.cookie = key + "=v; expires =" +date.toGMTString();//设置cookie
};
$pushCookie = function(key){
var data = $h.getCookie(key);
$h.delCookie(key);
return data;
};
$h.getParmas = function getUrlParam(name) {
var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //构造一个含有目标参数的正则表达式对象
var r = window.location.search.substr(1).match(reg); //匹配目标参数
if (r != null) return decodeURI(r[2]); return null; //返回参数值
};
$h.U = function(opt){
var m = opt.m || 'wap',c = opt.c || 'public_api', a = opt.a || 'index',q = opt.q || '',p = opt.p || {},_params = '',gets='',ext=opt.ext || '.html';
_params = Object.keys(p).map(function(key){
return key+'/'+p[key];
}).join('/');
if(typeof q=='object') gets = Object.keys(q).map(function (key) {
return key + '=' + q[key];
}).join('&');
return "/"+m+"/"+c+"/"+a+(_params == '' ? '' : '/'+_params)+ext+(gets == '' ? q : '?'+gets);
};
$h.isLogin = function(){
return !!parseInt($h.getCookie('is_login'));
};
$h.SplitArray=function(list,sp){
if (typeof list!='object') return [];
if (sp === undefined) sp=[];
for (var i = 0; i < list.length;i++){
sp.push(list[i]);
}
return sp;
}
$h.EventUtil ={
addHandler: function (element, type, handler) {
if (element.addEventListener)
element.addEventListener(type, handler, false);
else if (element.attachEvent)
element.attachEvent("on" + type, handler);
else
element["on" + type] = handler;
},
removeHandler: function (element, type, handler) {
if(element.removeEventListener)
element.removeEventListener(type, handler, false);
else if(element.detachEvent)
element.detachEvent("on" + type, handler);
else
element["on" + type] = handler;
},
/**
* 监听触摸的方向
* @param target 要绑定监听的目标元素
* @param isPreventDefault 是否屏蔽掉触摸滑动的默认行为例如页面的上下滚动缩放等
* @param upCallback 向上滑动的监听回调若不关心可以不传或传false
* @param rightCallback 向右滑动的监听回调若不关心可以不传或传false
* @param downCallback 向下滑动的监听回调若不关心可以不传或传false
* @param leftCallback 向左滑动的监听回调若不关心可以不传或传false
*/
listenTouchDirection: function (target, upCallback,isPreventDefault, rightCallback, downCallback, leftCallback) {
this.addHandler(target, "touchstart", handleTouchEvent);
this.addHandler(target, "touchend", handleTouchEvent);
this.addHandler(target, "touchmove", handleTouchEvent);
var startX;
var startY;
function handleTouchEvent(event) {
switch (event.type){
case "touchstart":
startX = event.touches[0].pageX;
startY = event.touches[0].pageY;
break;
case "touchend":
var spanX = event.changedTouches[0].pageX - startX;
var spanY = event.changedTouches[0].pageY - startY;
if(Math.abs(spanX) > Math.abs(spanY)) {
if (spanX > 30)
rightCallback && rightCallback();
else if (spanX < -30)
leftCallback && leftCallback();
}else {
if (spanY > 30)
downCallback && downCallback();
else if (spanY < -30) {
upCallback && upCallback();
}
}
break;
case "touchmove":
// if (event.cancelable) if(!event.defaultPrevented && !isPreventDefault) event.preventDefault();
break;
}
}
}
};
return $h;
});