UNPKG

icx-meum-vue-common-module

Version:

icx-meum-vue-common-module

507 lines (478 loc) 16.2 kB
// utils.js import { STRING_APP_TAG, STRING_DEVICE_TYPE_ANDROID, STRING_DEVICE_TYPE_IOS, MEUM, FIT_FORCE, FIT_FORCE_COACH, INADIE } from './const' // 是否为空或者空字符串 export const checkIsNullOrEmpty = (variable1) => variable1 === null || typeof variable1 === 'undefined' || variable1 === '' // 是否是微信浏览器 export const isWeChat = () => { let ua = navigator.userAgent.toLowerCase() return ua.match(/MicroMessenger/i) == 'micromessenger' } export const isIcarbonxApp = () => { const userAgent = navigator.userAgent.toLocaleLowerCase() const isIcarbonx = userAgent.indexOf('icarbonx') !== -1 const array = [MEUM, FIT_FORCE, FIT_FORCE_COACH, INADIE] return isIcarbonx || array.filter(item => userAgent.indexOf(item) !== -1).length > 0 } // 是否是觅我app export const isMeumApp = () => isIcarbonxApp() // 获取设备类型 export const getDeviceType = () => { let u = navigator.userAgent let isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > -1 let isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/) return isAndroid ? STRING_DEVICE_TYPE_ANDROID : isiOS ? STRING_DEVICE_TYPE_IOS : undefined } // 数字转换成大写字母 export const alphabet = (i) => (i + 9).toString(36).toUpperCase() export const isNullObj = obj => { for (let i in obj) { if (obj.hasOwnProperty(i)) { return false } } return true } /** * 存储localStorage */ export const setLocalStorage = (key, value) => { if (!key) return localStorage.setItem(key, JSON.stringify(value)) } /** * 获取localStorage */ export const getLocalStorage = key => { if (!key) return try { return JSON.parse(localStorage.getItem(key)) } catch (e) { return {} } } /** * 删除localStorage */ export const removeLocalStorage = key => { if (!key) return localStorage.removeItem(key) } /** * 存储sessionStorage */ export const setSessionStorage = (key, value) => { if (!key) return sessionStorage.setItem(key, JSON.stringify(value)) } /** * 获取sessionStorage */ export const getSessionStorage = key => { if (!key) return return JSON.parse(sessionStorage.getItem(key)) } /** * 删除sessionStorage */ export const removeSessionStorage = key => { if (!key) return window.sessionStorage.removeItem(key) } export const getBaseUrl = function (url) { var ishttps = document.location.protocol === 'https:' if (ishttps) { url = 'https://' + url } else { url = 'http://' + url } return url } // 将hex表示方式转换为rgb表示方式(这里返回rgb数组模式) export const colorRgb = function (color) { let reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/ let sColor = color.toLowerCase() if (sColor && reg.test(sColor)) { if (sColor.length === 4) { let sColorNew = '#' for (let i = 1; i < 4; i += 1) { sColorNew += sColor.slice(i, i + 1).concat(sColor.slice(i, i + 1)) } sColor = sColorNew } // 处理六位的颜色值 let sColorChange = [] for (var i = 1; i < 7; i += 2) { sColorChange.push(parseInt('0x' + sColor.slice(i, i + 2))) } return sColorChange } else { return sColor } } /** * iscroll配置,click点击事件 * @returns {boolean} */ export const iScrollClick = function () { if (/iPhone|iPad|iPod|Macintosh/i.test(navigator.userAgent)) return false if (/Chrome/i.test(navigator.userAgent)) return (/Android/i.test(navigator.userAgent)) if (/Silk/i.test(navigator.userAgent)) return false if (/Android/i.test(navigator.userAgent)) { var s = navigator.userAgent.substr(navigator.userAgent.indexOf('Android') + 8, 3) return !(parseFloat(s[0] + s[3]) < 44) } } // 将rgb表示方式转换为hex表示方式 export const colorHex = function (rgb) { let _this = rgb let reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/ if (/^(rgb|RGB)/.test(_this)) { let aColor = _this.replace(/(?:\(|\)|rgb|RGB)*/g, '').split(',') let strHex = '#' for (let i = 0; i < aColor.length; i++) { let hex = Number(aColor[i]).toString(16) hex = hex < 10 ? 0 + '' + hex : hex // 保证每个rgb的值为2位 if (hex === '0') { hex += hex } strHex += hex } if (strHex.length !== 7) { strHex = _this } return strHex } else if (reg.test(_this)) { let aNum = _this.replace(/#/, '').split('') if (aNum.length === 6) { return _this } else if (aNum.length === 3) { let numHex = '#' for (let i = 0; i < aNum.length; i += 1) { numHex += (aNum[i] + aNum[i]) } return numHex } } else { return _this } } /** * 根据百分比计算渐变色值 * @param startColor 起始色 * @param endColor 结束色 * @param ratio 比率 [0, 1] * @returns {number} */ export const gradientColor = function (startColor, endColor, ratio) { let sRGBColor = colorRgb(startColor) let startR = sRGBColor[0] let startG = sRGBColor[1] let startB = sRGBColor[2] let eRGBColor = colorRgb(endColor) let endR = eRGBColor[0] let endG = eRGBColor[1] let endB = eRGBColor[2] let resultRGB = 'rgb(' + parseInt(((endR - startR) * ratio + startR)) + ',' + parseInt(((endG - startG) * ratio + startG)) + ',' + parseInt(((endB - startB) * ratio + startB)) + ')' return colorHex(resultRGB) } /** * 字符串格式化模版 * @param template * @param data * @returns {*} */ export function stringFormatTemplate (template, data) { if (!data) { return template } let keys = Object.keys(data) let dataList dataList = keys.map(function (key) { return data[key] }) // 这里使用反引号来构建模板引擎 return new Function(keys.join(','), 'return `' + template + '`;').apply(null, dataList) } /** * 生成指定长度和基数的UUID * @example * uuid(8, 16) // "098F4D35" * @param {Int} len 长度 * @param {Int} radix 维度 * @return uuid */ export const getUUID = (len, radix) => { let chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('') let uuid = [] let i radix = radix || chars.length if (len) { // Compact form for (i = 0; i < len; i++) uuid[i] = chars[0 | Math.random() * radix] } else { // rfc4122, version 4 form let r // rfc4122 requires these characters uuid[8] = uuid[13] = uuid[18] = uuid[23] = '-' uuid[14] = '4' // Fill in random data. At i==19 set the high bits of clock sequence as // per rfc4122, sec. 4.1.5 for (i = 0; i < 36; i++) { if (!uuid[i]) { r = 0 | Math.random() * 16 uuid[i] = chars[(i === 19) ? (r & 0x3) | 0x8 : r] } } } return uuid.join('') } export const DateUtils = { /** * 将日期格式化成指定格式的字符串 * @param date 要格式化的日期,不传时默认当前时间,也可以是一个时间戳 * @param fmt 目标字符串格式,支持的字符有:y,M,d,q,w,H,h,m,S,默认:yyyy-MM-dd HH:mm:ss * @returns 返回格式化后的日期字符串 */ formatDate: function (date, fmt) { date = date == undefined ? new Date() : date date = typeof date == 'number' ? new Date(date) : date fmt = fmt || 'yyyy-MM-dd HH:mm:ss' var obj = { 'y': date.getFullYear(), // 年份,注意必须用getFullYear 'M': date.getMonth() + 1, // 月份,注意是从0-11 'd': date.getDate(), // 日期 'q': Math.floor((date.getMonth() + 3) / 3), // 季度 'w': date.getDay(), // 星期,注意是0-6 'H': date.getHours(), // 24小时制 'h': date.getHours() % 12 == 0 ? 12 : date.getHours() % 12, // 12小时制 'm': date.getMinutes(), // 分钟 's': date.getSeconds(), // 秒 'S': date.getMilliseconds() // 毫秒 } var week = ['天', '一', '二', '三', '四', '五', '六'] for (var i in obj) { fmt = fmt.replace(new RegExp(i + '+', 'g'), function (m) { var val = obj[i] + '' if (i == 'w') return (m.length > 2 ? '星期' : '周') + week[val] for (var j = 0, len = val.length; j < m.length - len; j++) val = '0' + val return m.length == 1 ? val : val.substring(val.length - m.length) }) } return fmt }, /** * 将字符串解析成日期 * @param str 输入的日期字符串,如'2014-09-13' * @param fmt 字符串格式,默认'yyyy-MM-dd',支持如下:y、M、d、H、m、s、S,不支持w和q * @returns 解析后的Date类型日期 */ parseDate: function (str, fmt) { fmt = fmt || 'yyyy-MM-dd' var obj = {y: 0, M: 1, d: 0, H: 0, h: 0, m: 0, s: 0, S: 0} fmt.replace(/([^yMdHmsS]*?)(([yMdHmsS])\3*)([^yMdHmsS]*?)/g, function (m, $1, $2, $3, $4, idx, old) { str = str.replace(new RegExp($1 + '(\\d{' + $2.length + '})' + $4), function (_m, _$1) { obj[$3] = parseInt(_$1) return '' }) return '' }) obj.M-- // 月份是从0开始的,所以要减去1 var date = new Date(obj.y, obj.M, obj.d, obj.H, obj.m, obj.s) if (obj.S !== 0) date.setMilliseconds(obj.S) // 如果设置了毫秒 return date }, /** * 将一个日期格式化成友好格式,比如,1分钟以内的返回“刚刚”, * 当天的返回时分,当年的返回月日,否则,返回年月日 * @param {Object} date */ formatDateToFriendly: function (date) { date = date || new Date() date = typeof date === 'number' ? new Date(date) : date var now = new Date() if ((now.getTime() - date.getTime()) < 60 * 1000) return '刚刚' // 1分钟以内视作“刚刚” var temp = this.formatDate(date, 'yyyy年M月d') if (temp == this.formatDate(now, 'yyyy年M月d')) return this.formatDate(date, 'HH:mm') if (date.getFullYear() == now.getFullYear()) return this.formatDate(date, 'M月d日') return temp }, /** * 将一个日期格式化成友好格式,比如,1分钟以内的返回“刚刚”, * 当天的返回时分,当年的返回月日,否则,返回年月日 * @param {Object} date */ formatMessageDateToFriendly: function (date) { date = date || new Date() date = typeof date === 'number' ? new Date(date) : date var now = new Date() var diff = now.getTime() - date.getTime() var toadyDiff = new Date(this.formatDate(new Date(), 'yyyy/MM/dd') + ' 00:00:00') var oneDay = 24 * 60 * 60 * 1000 if (diff < 60 * 1000) return '刚刚' // 1分钟以内视作“刚刚” if (now.getTime() > date.getTime() && date.getTime() > toadyDiff.getTime()) return this.formatDate(date, 'HH:mm') if (date.getTime() < toadyDiff.getTime() && date.getTime() > (toadyDiff.getTime() - oneDay)) return '昨天' + this.formatDate(date, ' HH:mm') if (date.getTime() < toadyDiff.getTime() && date.getTime() > (toadyDiff.getTime() - 2 * oneDay)) return '前天' + this.formatDate(date, ' HH:mm') if (date.getFullYear() == now.getFullYear()) return this.formatDate(date, 'M月d日 HH:mm') var temp = this.formatDate(date, 'yyyy年M月d HH:mm') return temp }, /** * 将一段时长转换成友好格式,如: * 147->“2分27秒” * 1581->“26分21秒” * 15818->“4小时24分” * @param {Object} second */ formatDurationToFriendly: function (second) { if (second < 60) return second + '秒' else if (second < 60 * 60) return (second - second % 60) / 60 + '分' + second % 60 + '秒' else if (second < 60 * 60 * 24) return (second - second % 3600) / 60 / 60 + '小时' + Math.round(second % 3600 / 60) + '分' return (second / 60 / 60 / 24).toFixed(1) + '天' }, /** * 将时间转换成MM:SS形式 */ formatTimeToFriendly: function (second) { var m = Math.floor(second / 60) m = m < 10 ? ('0' + m) : m var s = second % 60 s = s < 10 ? ('0' + s) : s return m + ':' + s }, /** * 判断某一年是否是闰年 * @param year 可以是一个date类型,也可以是一个int类型的年份,不传默认当前时间 */ isLeapYear: function (year) { if (year === undefined) year = new Date() if (year instanceof Date) year = year.getFullYear() return (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0) }, /** * 获取某一年某一月的总天数,没有任何参数时获取当前月份的 * 方式一:$.getMonthDays(); * 方式二:$.getMonthDays(new Date()); * 方式三:$.getMonthDays(2013, 12); */ getMonthDays: function (date, month) { var y, m if (date == undefined) date = new Date() if (date instanceof Date) { y = date.getFullYear() m = date.getMonth() } else if (typeof date == 'number') { y = date m = month - 1 } var days = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31] // 非闰年的一年中每个月份的天数 // 如果是闰年并且是2月 if (m == 1 && this.isLeapYear(y)) return days[m] + 1 return days[m] }, /** * 计算2日期之间的天数,用的是比较毫秒数的方法 * 传进来的日期要么是Date类型,要么是yyyy-MM-dd格式的字符串日期 * @param date1 日期一 * @param date2 日期二 */ countDays: function (date1, date2) { var fmt = 'yyyy-MM-dd' // 将日期转换成字符串,转换的目的是去除“时、分、秒” if (date1 instanceof Date && date2 instanceof Date) { date1 = this.formatDate(date1, fmt) date2 = this.formatDate(date2, fmt) } if (typeof date1 === 'string' && typeof date2 === 'string') { date1 = this.parseDate(date1, fmt) date2 = this.parseDate(date2, fmt) return (date1.getTime() - date2.getTime()) / (1000 * 60 * 60 * 24) } else { console.error('参数格式无效!') return 0 } }, /** * 返回两天之间的天数 * @param value1 * @param value2 * @returns {Array} */ getDataScope (value1, value2) { var getDate = function (str) { var tempDate = new Date() var list = str.split('-') tempDate.setFullYear(list[0]) tempDate.setMonth(list[1] - 1) tempDate.setDate(list[2]) return tempDate } var date1 = getDate(value1) var date2 = getDate(value2) if (date1 > date2) { var tempDate = date1 date1 = date2 date2 = tempDate } date1.setDate(date1.getDate() + 1) var dateArr = [] var i = 0 while (!(date1.getFullYear() == date2.getFullYear() && date1.getMonth() == date2.getMonth() && date1.getDate() == date2.getDate())) { dateArr[i] = date1 i++ date1.setDate(date1.getDate() + 1) } return dateArr } } /** * @description 左侧补0得到制定长度值 */ export const prefixInteger = (num, length) => { return (Array(length).join(0) + num).slice(-length) } // 字符串首字母大写 String.prototype.firstUpperCase = function () { return this.toString()[0].toUpperCase() + this.toString().slice(1) } function render (template, context) { let tokenReg = /(\\)?\{([^{}\\]+)(\\)?\}/g return template.replace(tokenReg, function (word, slash1, token, slash2) { if (slash1 || slash2) { return word.replace('\\', '') } let variables = token.replace(/\s/g, '').split('.') let currentObject = context let i, length, variable for (i = 0, length = variables.length; i < length; ++i) { variable = variables[i] currentObject = currentObject[variable] if (currentObject === undefined || currentObject === null) return '' } return currentObject }) } String.prototype.render = function (context) { return render(this, context) } // 日期格式化 Date.prototype.format = function (fmt) { let o = { 'M+': this.getMonth() + 1, 'd+': this.getDate(), 'h+': this.getHours(), 'm+': this.getMinutes(), 's+': this.getSeconds(), 'q+': Math.floor((this.getMonth() + 3) / 3), 'S': this.getMilliseconds() } if (/(y+)/.test(fmt)) { fmt = fmt.replace(RegExp.$1, (this.getFullYear() + '').substr(4 - RegExp.$1.length)) } for (let k in o) { if (new RegExp('(' + k + ')').test(fmt)) { fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length))) } } return fmt }