386 lines
8.1 KiB
JavaScript
386 lines
8.1 KiB
JavaScript
|
// +----------------------------------------------------------------------
|
|||
|
// | likeshop开源商城系统
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
|
|||
|
// | gitee下载:https://gitee.com/likeshop_gitee
|
|||
|
// | github下载:https://github.com/likeshop-github
|
|||
|
// | 访问官网:https://www.likeshop.cn
|
|||
|
// | 访问社区:https://home.likeshop.cn
|
|||
|
// | 访问手册:http://doc.likeshop.cn
|
|||
|
// | 微信公众号:likeshop技术社区
|
|||
|
// | likeshop系列产品在gitee、github等公开渠道开源版本可免费商用,未经许可不能去除前后端官方版权标识
|
|||
|
// | likeshop系列产品收费版本务必购买商业授权,购买去版权授权后,方可去除前后端官方版权标识
|
|||
|
// | 禁止对系统程序代码以任何目的,任何形式的再发布
|
|||
|
// | likeshop团队版权所有并拥有最终解释权
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | author: likeshop.cn.team
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
|
|||
|
import {
|
|||
|
loadingType
|
|||
|
} from './type'
|
|||
|
import {
|
|||
|
baseURL
|
|||
|
} from '@/config/app.js'
|
|||
|
|
|||
|
import store from '@/store'
|
|||
|
|
|||
|
|
|||
|
//所在环境
|
|||
|
let client = null
|
|||
|
// #ifdef MP-WEIXIN
|
|||
|
client = 1
|
|||
|
// #endif
|
|||
|
|
|||
|
// #ifdef H5
|
|||
|
client = isWeixinClient() ? 2 : 6
|
|||
|
// #endif
|
|||
|
|
|||
|
// #ifdef APP-PLUS
|
|||
|
client = 3;
|
|||
|
uni.getSystemInfo({
|
|||
|
success: res => {
|
|||
|
client = res.platform == 'ios' ? 3 : 4;
|
|||
|
},
|
|||
|
fail: res => {
|
|||
|
client = 3
|
|||
|
}
|
|||
|
})
|
|||
|
// #endif
|
|||
|
export {
|
|||
|
client
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//节流
|
|||
|
export const trottle = (func, time = 1000, context) => {
|
|||
|
let previous = new Date(0).getTime()
|
|||
|
return function(...args) {
|
|||
|
let now = new Date().getTime()
|
|||
|
if (now - previous > time) {
|
|||
|
func.apply(context, args)
|
|||
|
previous = now
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//节流
|
|||
|
export const debounce = (func, time = 1000, context) => {
|
|||
|
let timer = null
|
|||
|
return function(...args) {
|
|||
|
if (timer) {
|
|||
|
clearTimeout(timer)
|
|||
|
}
|
|||
|
timer = setTimeout(() => {
|
|||
|
timer = null
|
|||
|
func.apply(context, args)
|
|||
|
}, time)
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//判断是否为微信环境
|
|||
|
export function isWeixinClient() {
|
|||
|
var ua = navigator.userAgent.toLowerCase();
|
|||
|
if (ua.match(/MicroMessenger/i) == "micromessenger") {
|
|||
|
//这是微信环境
|
|||
|
return true;
|
|||
|
} else {
|
|||
|
//这是非微信环境
|
|||
|
return false;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//判断是否为安卓环境
|
|||
|
export function isAndroid() {
|
|||
|
let u = navigator.userAgent;
|
|||
|
return u.indexOf('Android') > -1 || u.indexOf('Adr') > -1;
|
|||
|
}
|
|||
|
|
|||
|
//获取url后的参数 以对象返回
|
|||
|
export function strToParams(str) {
|
|||
|
var newparams = {}
|
|||
|
for (let item of str.split('&')) {
|
|||
|
newparams[item.split('=')[0]] = item.split('=')[1]
|
|||
|
}
|
|||
|
return newparams
|
|||
|
}
|
|||
|
|
|||
|
//重写encodeURL函数
|
|||
|
export function urlencode(str) {
|
|||
|
str = (str + '').toString();
|
|||
|
return encodeURIComponent(str).replace(/!/g, '%21').replace(/'/g, '%27').replace(/\(/g, '%28').
|
|||
|
replace(/\)/g, '%29').replace(/\*/g, '%2A').replace(/%20/g, '+');
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//一维数组截取为二维数组
|
|||
|
|
|||
|
export function arraySlice(data, array = [], optNum = 10) {
|
|||
|
data = JSON.parse(JSON.stringify(data))
|
|||
|
if (data.length <= optNum) {
|
|||
|
data.length > 0 && array.push(data);
|
|||
|
return array;
|
|||
|
}
|
|||
|
array.push(data.splice(0, optNum));
|
|||
|
return arraySlice(data, array, optNum);
|
|||
|
}
|
|||
|
|
|||
|
//对象参数转为以?&拼接的字符
|
|||
|
export function paramsToStr(params) {
|
|||
|
let p = '';
|
|||
|
if (typeof params == 'object') {
|
|||
|
p = '?'
|
|||
|
for (let props in params) {
|
|||
|
p += `${props}=${params[props]}&`
|
|||
|
}
|
|||
|
p = p.slice(0, -1)
|
|||
|
}
|
|||
|
return p
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// 获取wxml元素
|
|||
|
|
|||
|
export function getRect(selector, all, context) {
|
|||
|
return new Promise(function(resolve) {
|
|||
|
let qurey = uni.createSelectorQuery();
|
|||
|
|
|||
|
if (context) {
|
|||
|
qurey = uni.createSelectorQuery().in(context);
|
|||
|
}
|
|||
|
|
|||
|
qurey[all ? 'selectAll' : 'select'](selector).boundingClientRect(function(rect) {
|
|||
|
if (all && Array.isArray(rect) && rect.length) {
|
|||
|
resolve(rect);
|
|||
|
}
|
|||
|
if (!all && rect) {
|
|||
|
resolve(rect);
|
|||
|
}
|
|||
|
}).exec();
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
// 轻提示
|
|||
|
export function toast(info = {}, navigateOpt) {
|
|||
|
let title = info.title || ''
|
|||
|
let icon = info.icon || 'none'
|
|||
|
let endtime = info.endtime || 2000
|
|||
|
if (title) uni.showToast({
|
|||
|
title: title,
|
|||
|
icon: icon,
|
|||
|
duration: endtime
|
|||
|
})
|
|||
|
if (navigateOpt != undefined) {
|
|||
|
if (typeof navigateOpt == 'object') {
|
|||
|
let tab = navigateOpt.tab || 1,
|
|||
|
url = navigateOpt.url || '';
|
|||
|
switch (tab) {
|
|||
|
case 1:
|
|||
|
//跳转至 table
|
|||
|
setTimeout(function() {
|
|||
|
uni.switchTab({
|
|||
|
url: url
|
|||
|
})
|
|||
|
}, endtime);
|
|||
|
break;
|
|||
|
case 2:
|
|||
|
//跳转至非table页面
|
|||
|
setTimeout(function() {
|
|||
|
uni.navigateTo({
|
|||
|
url: url,
|
|||
|
})
|
|||
|
}, endtime);
|
|||
|
break;
|
|||
|
case 3:
|
|||
|
//返回上页面
|
|||
|
setTimeout(function() {
|
|||
|
uni.navigateBack({
|
|||
|
delta: parseInt(url),
|
|||
|
})
|
|||
|
}, endtime);
|
|||
|
break;
|
|||
|
case 4:
|
|||
|
//关闭当前所有页面跳转至非table页面
|
|||
|
setTimeout(function() {
|
|||
|
uni.reLaunch({
|
|||
|
url: url,
|
|||
|
})
|
|||
|
}, endtime);
|
|||
|
break;
|
|||
|
case 5:
|
|||
|
//关闭当前页面跳转至非table页面
|
|||
|
setTimeout(function() {
|
|||
|
uni.redirectTo({
|
|||
|
url: url,
|
|||
|
})
|
|||
|
}, endtime);
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
} else if (typeof navigateOpt == 'function') {
|
|||
|
setTimeout(function() {
|
|||
|
navigateOpt && navigateOpt();
|
|||
|
}, endtime);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//菜单跳转
|
|||
|
export function menuJump(item) {
|
|||
|
const {
|
|||
|
is_tab,
|
|||
|
link,
|
|||
|
link_type
|
|||
|
} = item
|
|||
|
switch (link_type) {
|
|||
|
case 1:
|
|||
|
// 本地跳转
|
|||
|
if (is_tab) {
|
|||
|
uni.switchTab({
|
|||
|
url: link
|
|||
|
});
|
|||
|
return;
|
|||
|
}
|
|||
|
uni.navigateTo({
|
|||
|
url: link
|
|||
|
});
|
|||
|
break;
|
|||
|
|
|||
|
case 2:
|
|||
|
// webview
|
|||
|
uni.navigateTo({
|
|||
|
url: "/pages/webview/webview?url=" + link
|
|||
|
});
|
|||
|
break;
|
|||
|
|
|||
|
case 3: // tabbar
|
|||
|
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
export function uploadFile(path) {
|
|||
|
return new Promise((resolve, reject) => {
|
|||
|
uni.uploadFile({
|
|||
|
url: baseURL + '/api/file/formimage',
|
|||
|
filePath: path,
|
|||
|
name: 'file',
|
|||
|
header: {
|
|||
|
token: store.getters.token,
|
|||
|
// version: '1.2.1.20210717'
|
|||
|
},
|
|||
|
fileType: 'image',
|
|||
|
cloudPath: '',
|
|||
|
success: res => {
|
|||
|
try {
|
|||
|
console.log(path)
|
|||
|
console.log('uploadFile res ==> ', res)
|
|||
|
let data = JSON.parse(res.data);
|
|||
|
|
|||
|
if (data.code == 1) {
|
|||
|
resolve(data.data);
|
|||
|
} else {
|
|||
|
reject()
|
|||
|
}
|
|||
|
} catch (e) {
|
|||
|
console.log(e)
|
|||
|
reject()
|
|||
|
}
|
|||
|
},
|
|||
|
fail: (err) => {
|
|||
|
console.log(err)
|
|||
|
reject()
|
|||
|
}
|
|||
|
});
|
|||
|
});
|
|||
|
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
//当前页面
|
|||
|
|
|||
|
export function currentPage() {
|
|||
|
let pages = getCurrentPages();
|
|||
|
let currentPage = pages[pages.length - 1];
|
|||
|
return currentPage || {};
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// H5复制方法
|
|||
|
export function copy(str) {
|
|||
|
// #ifdef H5
|
|||
|
let aux = document.createElement("input");
|
|||
|
aux.setAttribute("value", str);
|
|||
|
document.body.appendChild(aux);
|
|||
|
aux.select();
|
|||
|
document.execCommand("copy");
|
|||
|
document.body.removeChild(aux);
|
|||
|
uni.showToast({
|
|||
|
title: "复制成功",
|
|||
|
})
|
|||
|
// #endif
|
|||
|
|
|||
|
// #ifndef H5
|
|||
|
uni.setClipboardData({
|
|||
|
data: str.toString(),
|
|||
|
})
|
|||
|
// #endif
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
export function setTabbar() {
|
|||
|
const config = store.getters.appConfig
|
|||
|
uni.setTabBarStyle({
|
|||
|
color: config.navigation_setting.ust_color,
|
|||
|
selectedColor: config.navigation_setting.st_color,
|
|||
|
})
|
|||
|
// #ifdef APP-PLUS
|
|||
|
config.navigation_menu.forEach((item, index) => {
|
|||
|
uni.downloadFile({
|
|||
|
url: item.un_selected_icon,
|
|||
|
success: res => {
|
|||
|
uni.setTabBarItem({
|
|||
|
index,
|
|||
|
iconPath: res.tempFilePath,
|
|||
|
})
|
|||
|
}
|
|||
|
});
|
|||
|
uni.downloadFile({
|
|||
|
url: item.selected_icon,
|
|||
|
success: res => {
|
|||
|
uni.setTabBarItem({
|
|||
|
index,
|
|||
|
selectedIconPath: res.tempFilePath,
|
|||
|
})
|
|||
|
}
|
|||
|
});
|
|||
|
uni.setTabBarItem({
|
|||
|
index,
|
|||
|
text: item.name,
|
|||
|
fail(res) {
|
|||
|
console.log(res)
|
|||
|
},
|
|||
|
success(res) {
|
|||
|
console.log(res)
|
|||
|
}
|
|||
|
})
|
|||
|
})
|
|||
|
// #endif
|
|||
|
// #ifndef APP-PLUS
|
|||
|
config.navigation_menu.forEach((item, index) => {
|
|||
|
uni.setTabBarItem({
|
|||
|
index,
|
|||
|
text: item.name,
|
|||
|
iconPath: item.un_selected_icon,
|
|||
|
selectedIconPath: item.selected_icon,
|
|||
|
fail(res) {},
|
|||
|
success(res) {}
|
|||
|
})
|
|||
|
})
|
|||
|
// #endif
|
|||
|
}
|