util.js 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. /**
  2. * 通用js方法封装处理
  3. * Copyright (c) 2019 ygp
  4. */
  5. const baseURL = process.env.VUE_APP_BASE_API
  6. // 日期格式化
  7. export function parseTime(time, pattern) {
  8. if (arguments.length === 0 || !time) {
  9. return null
  10. }
  11. const format = pattern || '{y}-{m}-{d} {h}:{i}:{s}'
  12. let date
  13. if (typeof time === 'object') {
  14. date = time
  15. } else {
  16. if ((typeof time === 'string') && (/^[0-9]+$/.test(time))) {
  17. time = parseInt(time)
  18. } else if (typeof time === 'string') {
  19. time = time.replace(new RegExp(/-/gm), '/');
  20. }
  21. if ((typeof time === 'number') && (time.toString().length === 10)) {
  22. time = time * 1000
  23. }
  24. date = new Date(time)
  25. }
  26. const formatObj = {
  27. y: date.getFullYear(),
  28. m: date.getMonth() + 1,
  29. d: date.getDate(),
  30. h: date.getHours(),
  31. i: date.getMinutes(),
  32. s: date.getSeconds(),
  33. a: date.getDay()
  34. }
  35. const time_str = format.replace(/{(y|m|d|h|i|s|a)+}/g, (result, key) => {
  36. let value = formatObj[key]
  37. // Note: getDay() returns 0 on Sunday
  38. if (key === 'a') {
  39. return ['日', '一', '二', '三', '四', '五', '六'][value]
  40. }
  41. if (result.length > 0 && value < 10) {
  42. value = '0' + value
  43. }
  44. return value || 0
  45. })
  46. return time_str
  47. }
  48. // 表单重置
  49. export function resetForm(refName) {
  50. if (this.$refs[refName]) {
  51. this.$refs[refName].resetFields();
  52. }
  53. }
  54. // 添加日期范围
  55. export function addDateRange(params, dateRange, propName) {
  56. let search = params;
  57. search.params = typeof (search.params) === 'object' && search.params !== null && !Array.isArray(search.params) ? search.params : {};
  58. dateRange = Array.isArray(dateRange) ? dateRange : [];
  59. if (typeof (propName) === 'undefined') {
  60. search.params['beginTime'] = dateRange[0];
  61. search.params['endTime'] = dateRange[1];
  62. } else {
  63. search.params['begin' + propName] = dateRange[0];
  64. search.params['end' + propName] = dateRange[1];
  65. }
  66. return search;
  67. }
  68. // 回显数据字典
  69. export function selectDictLabel(datas, value) {
  70. var actions = [];
  71. Object.keys(datas).some((key) => {
  72. if (datas[key].dictValue == ('' + value)) {
  73. actions.push(datas[key].dictLabel);
  74. return true;
  75. }
  76. })
  77. return actions.join('');
  78. }
  79. // 回显数据字典(字符串数组)
  80. export function selectDictLabels(datas, value, separator) {
  81. var actions = [];
  82. var currentSeparator = undefined === separator ? "," : separator;
  83. var temp = value.split(currentSeparator);
  84. Object.keys(value.split(currentSeparator)).some((val) => {
  85. Object.keys(datas).some((key) => {
  86. if (datas[key].dictValue == ('' + temp[val])) {
  87. actions.push(datas[key].dictLabel + currentSeparator);
  88. }
  89. })
  90. })
  91. return actions.join('').substring(0, actions.join('').length - 1);
  92. }
  93. // 通用下载方法
  94. export function download(fileName) {
  95. window.location.href = baseURL + "/common/download?fileName=" + encodeURI(fileName) + "&delete=" + true;
  96. }
  97. // 字符串格式化(%s )
  98. export function sprintf(str) {
  99. var args = arguments,
  100. flag = true,
  101. i = 1;
  102. str = str.replace(/%s/g, function () {
  103. var arg = args[i++];
  104. if (typeof arg === 'undefined') {
  105. flag = false;
  106. return '';
  107. }
  108. return arg;
  109. });
  110. return flag ? str : '';
  111. }
  112. // 转换字符串,undefined,null等转化为""
  113. export function praseStrEmpty(str) {
  114. if (!str || str == "undefined" || str == "null") {
  115. return "";
  116. }
  117. return str;
  118. }
  119. // 获取20位长度的随机字符串
  120. export function randomStr20() {
  121. for (var e = "0123456789abcdef", t = "", n = 0; n < 20; n++) t += e[Math.floor(16 * Math.random())];
  122. return t;
  123. }
  124. /*
  125. * 参数说明:
  126. * number:要转换的数字
  127. * thousand:千分位符号
  128. * */
  129. //千分位转正常数字
  130. export function toNumber(number,thousand){
  131. number = number.split(thousand).join("");
  132. return parseFloat(number)
  133. }
  134. //除法去除精度损失
  135. export function accDiv(arg1, arg2) {
  136. if(!arg1 || !arg2){
  137. if(arg2 == 0){
  138. return Infinity
  139. }
  140. return arg1/arg2
  141. }
  142. var t1 = 0, t2 = 0, r1, r2;
  143. try { t1 = arg1.toString().split(".")[1].length } catch (e) { }
  144. try { t2 = arg2.toString().split(".")[1].length } catch (e) { }
  145. r1 = Number(arg1.toString().replace(".", ""));
  146. r2 = Number(arg2.toString().replace(".", ""));
  147. if(r2==0){
  148. return Infinity;
  149. }else{
  150. return (r1 / r2) * Math.pow(10, t2 - t1);
  151. }
  152. }
  153. //乘法去除精度损失
  154. export function accMul(arg1, arg2) {
  155. if(!arg1 || !arg2){
  156. return arg1*arg2
  157. }
  158. var m = 0, s1 = arg1.toString(), s2 = arg2.toString();
  159. try { m += s1.split(".")[1].length } catch (e) { }
  160. try { m += s2.split(".")[1].length } catch (e) { }
  161. return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m);
  162. }
  163. export function numberFormat(number, decimals = 2, dec_point = '.', thousands_sep = ',') {
  164. /*
  165. * 参数说明:
  166. * number:要格式化的数字
  167. * decimals:保留几位小数
  168. * dec_point:小数点符号
  169. * thousands_sep:千分位符号
  170. * */
  171. number = accDiv(number,100)
  172. number = (number + '').replace(/[^0-9+-Ee.]/g, '');
  173. var n = !isFinite(+number) ? 0 : +number,
  174. prec = !isFinite(+decimals) ? 0 : Math.abs(decimals),
  175. sep = (typeof thousands_sep === 'undefined') ? ',' : thousands_sep,
  176. dec = (typeof dec_point === 'undefined') ? '.' : dec_point,
  177. s = '',
  178. toFixedFix = function (n, prec) {
  179. var k = Math.pow(10, prec);
  180. return '' + Math.round(n * k) / k;
  181. };
  182. s = (prec ? toFixedFix(n, prec) : '' + Math.round(n)).split('.');
  183. var re = /(-?\d+)(\d{3})/;
  184. while (re.test(s[0])) {
  185. s[0] = s[0].replace(re, "$1" + sep + "$2");
  186. }
  187. if ((s[1] || '').length < prec) {
  188. s[1] = s[1] || '';
  189. s[1] += new Array(prec - s[1].length + 1).join('0');
  190. }
  191. return s.join(dec);
  192. }
  193. export function newNumberFormat(number, decimals, dec_point, thousands_sep) {
  194. /*
  195. * 参数说明:
  196. * number:要格式化的数字
  197. * decimals:保留几位小数
  198. * dec_point:小数点符号
  199. * thousands_sep:千分位符号
  200. * */
  201. number = (number + '').replace(/[^0-9+-Ee.]/g, '');
  202. var n = !isFinite(+number) ? 0 : +number,
  203. prec = !isFinite(+decimals) ? 0 : Math.abs(decimals),
  204. sep = (typeof thousands_sep === 'undefined') ? ',' : thousands_sep,
  205. dec = (typeof dec_point === 'undefined') ? '.' : dec_point,
  206. s = '',
  207. toFixedFix = function (n, prec) {
  208. var k = Math.pow(10, prec);
  209. return '' + Math.round(n * k) / k;
  210. };
  211. s = (prec ? toFixedFix(n, prec) : '' + Math.round(n)).split('.');
  212. var re = /(-?\d+)(\d{3})/;
  213. while (re.test(s[0])) {
  214. s[0] = s[0].replace(re, "$1" + sep + "$2");
  215. }
  216. if ((s[1] || '').length < prec) {
  217. s[1] = s[1] || '';
  218. s[1] += new Array(prec - s[1].length + 1).join('0');
  219. }
  220. return s.join(dec);
  221. }
  222. /**
  223. * 构造树型结构数据
  224. * @param {*} data 数据源
  225. * @param {*} id id字段 默认 'id'
  226. * @param {*} parentId 父节点字段 默认 'parentId'
  227. * @param {*} children 孩子节点字段 默认 'children'
  228. */
  229. export function handleTree(data, id, parentId, children) {
  230. let config = {
  231. id: id || 'id',
  232. parentId: parentId || 'parentId',
  233. childrenList: children || 'children'
  234. };
  235. var childrenListMap = {};
  236. var nodeIds = {};
  237. var tree = [];
  238. for (let d of data) {
  239. let parentId = d[config.parentId];
  240. if (childrenListMap[parentId] == null) {
  241. childrenListMap[parentId] = [];
  242. }
  243. nodeIds[d[config.id]] = d;
  244. childrenListMap[parentId].push(d);
  245. }
  246. for (let d of data) {
  247. let parentId = d[config.parentId];
  248. if (nodeIds[parentId] == null) {
  249. tree.push(d);
  250. }
  251. }
  252. for (let t of tree) {
  253. adaptToChildrenList(t);
  254. }
  255. function adaptToChildrenList(o) {
  256. if (childrenListMap[o[config.id]] !== null) {
  257. o[config.childrenList] = childrenListMap[o[config.id]];
  258. }
  259. if (o[config.childrenList]) {
  260. for (let c of o[config.childrenList]) {
  261. adaptToChildrenList(c);
  262. }
  263. }
  264. }
  265. return tree;
  266. }
  267. // 关闭当前页 关联tagView
  268. export function closePage(store, router, route) {
  269. var currentView = store.state.tagsView.visitedViews[0]
  270. for (currentView of store.state.tagsView.visitedViews) {
  271. if (currentView.path === route.path) {
  272. break
  273. }
  274. }
  275. store.dispatch('tagsView/delView', currentView)
  276. .then(({ visitedViews }) => {
  277. if (currentView.path === route.path) {
  278. const latestView = store.state.tagsView.visitedViews.slice(-1)[0]
  279. if (latestView) {
  280. router.push(latestView)
  281. } else {
  282. if (currentView.name === '首页') {
  283. router.replace({ path: '/redirect' + currentView.fullPath })
  284. } else {
  285. router.push('/')
  286. }
  287. }
  288. }
  289. })
  290. }
  291. export function getTimeResult(time){
  292. //当前的时间戳
  293. var ctime = new Date().getTime();
  294. // console.log("time:"+time);
  295. // console.log("ctime"+ctime)
  296. //当前时间戳-传入的时间戳=时间差
  297. var difference = ctime-time;
  298. // console.log(difference)
  299. //把时间差转换成天数
  300. var day = Math.floor(difference/3600/24/1000);
  301. //如果天数大于等于1小于7
  302. if(day>=1 && day<7){
  303. return day+'天前';
  304. }
  305. if(day<1){
  306. var hour = Math.floor(difference/3600/1000);
  307. if(hour<1){
  308. var min = Math.floor(difference/60/1000);
  309. if(min<1){
  310. return '刚刚'
  311. }
  312. return min+'分钟前';
  313. }else{
  314. return hour+'小时前';
  315. }
  316. }
  317. if(day>=7){
  318. return parseTime(time,'{y}.{m}.{d}');
  319. }
  320. }