util.js 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. // import { isURL } from '@/utils/validate'
  2. import {formt} from "./filters";
  3. //获取地址栏参数
  4. export function getUrlParams(str) {
  5. if (str) {
  6. const _arr = str.split('?');
  7. const arr = _arr[1].split('&');
  8. return arr.reduce(function (json, val) {
  9. const _tmp = val.split('=');
  10. json[_tmp[0]] = _tmp[1];
  11. return json
  12. }, {})
  13. }
  14. return {}
  15. }
  16. //判断是否为今天
  17. export function isToday(str) {
  18. const d = new Date(str.replace(/-/g, "/"));
  19. const todaysDate = new Date();
  20. if (d.setHours(0, 0, 0, 0) == todaysDate.setHours(0, 0, 0, 0)) {
  21. return true;
  22. } else {
  23. return false;
  24. }
  25. }
  26. export function timeFix() {
  27. const time = new Date()
  28. const hour = time.getHours()
  29. return hour < 9 ? '早上好' : (hour <= 11 ? '上午好' : (hour <= 13 ? '中午好' : (hour < 20 ? '下午好' : '晚上好')))
  30. }
  31. export function welcome() {
  32. const arr = ['休息一会儿吧', '准备吃什么呢?', '要不要打一把 DOTA', '我猜你可能累了']
  33. let index = Math.floor((Math.random() * arr.length))
  34. return arr[index]
  35. }
  36. /**
  37. * 触发 window.resize
  38. */
  39. export function triggerWindowResizeEvent() {
  40. let event = document.createEvent('HTMLEvents')
  41. event.initEvent('resize', true, true)
  42. event.eventType = 'message';
  43. window.dispatchEvent(event)
  44. }
  45. /**
  46. * 过滤对象中为空的属性
  47. * @param obj
  48. * @returns {*}
  49. */
  50. export function filterObj(obj) {
  51. if (!(typeof obj == 'object')) {
  52. return;
  53. }
  54. for (var key in obj) {
  55. if (obj.hasOwnProperty(key)
  56. && obj[key] !== 0 && (obj[key] == null || obj[key] == undefined || obj[key] === '')) {
  57. delete obj[key];
  58. }
  59. }
  60. return obj;
  61. }
  62. export function dk_formatDate(value, fmt, status) {
  63. if (value) {
  64. const _date = value.replace ? new Date(value.replace(/-/g, "/")) : new Date(value);
  65. if (_date) {
  66. const Y = _date.getFullYear();
  67. const M = _date.getMonth() + 1;
  68. const D = _date.getDate();
  69. const H = _date.getHours();
  70. const m = _date.getMinutes();
  71. const s = _date.getSeconds();
  72. if (fmt === '年') {
  73. if (status) {
  74. return formt(Y) + '年' + formt(M) + '月' + formt(D) + '日' + ' ' + [H, m, s].map(formt).join(':')
  75. }
  76. return formt(Y) + '年' + formt(M) + '月' + formt(D) + '日'
  77. } else {
  78. if (status) {
  79. return [Y, M, D].map(formt).join(fmt) + ' ' + [H, m, s].map(formt).join(':')
  80. }
  81. return [Y, M, D].map(formt).join(fmt);
  82. }
  83. }
  84. }
  85. return ''
  86. }
  87. /**
  88. * 时间格式化
  89. * @param value
  90. * @param fmt
  91. * @returns {*}
  92. */
  93. export function formatDate(value, fmt) {
  94. var regPos = /^\d+(\.\d+)?$/;
  95. if (regPos.test(value)) {
  96. //如果是数字
  97. let getDate = new Date(value);
  98. let o = {
  99. 'M+': getDate.getMonth() + 1,
  100. 'd+': getDate.getDate(),
  101. 'h+': getDate.getHours(),
  102. 'm+': getDate.getMinutes(),
  103. 's+': getDate.getSeconds(),
  104. 'q+': Math.floor((getDate.getMonth() + 3) / 3),
  105. 'S': getDate.getMilliseconds()
  106. };
  107. if (/(y+)/.test(fmt)) {
  108. fmt = fmt.replace(RegExp.$1, (getDate.getFullYear() + '').substr(4 - RegExp.$1.length))
  109. }
  110. for (let k in o) {
  111. if (new RegExp('(' + k + ')').test(fmt)) {
  112. fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length)))
  113. }
  114. }
  115. return fmt;
  116. } else {
  117. //TODO
  118. value = value.trim();
  119. return value.substr(0, fmt.length);
  120. }
  121. }
  122. // 生成首页路由
  123. // export function generateIndexRouter(data) {
  124. // let indexRouter = [{
  125. // path: '/',
  126. // name: 'dashboard',
  127. // //component: () => import('@/components/layouts/BasicLayout'),
  128. // component: resolve => require(['@/components/layouts/TabLayout'], resolve),
  129. // meta: { title: '首页' },
  130. // redirect: '/dashboard/analysis',
  131. // children: [
  132. // ...generateChildRouters(data)
  133. // ]
  134. // },{
  135. // "path": "*", "redirect": "/404", "hidden": true
  136. // }]
  137. // return indexRouter;
  138. // }
  139. // 生成嵌套路由(子路由)
  140. // function generateChildRouters (data) {
  141. // const routers = [];
  142. // for (var item of data) {
  143. // let component = "";
  144. // if(item.component.indexOf("layouts")>=0){
  145. // component = "components/"+item.component;
  146. // }else{
  147. // component = "views/"+item.component;
  148. // }
  149. //
  150. // // eslint-disable-next-line
  151. // let URL = (item.meta.url|| '').replace(/{{([^}}]+)?}}/g, (s1, s2) => eval(s2)) // URL支持{{ window.xxx }}占位符变量
  152. // if (isURL(URL)) {
  153. // item.meta.url = URL;
  154. // }
  155. //
  156. // let menu = {
  157. // path: item.path,
  158. // name: item.name,
  159. // redirect:item.redirect,
  160. // component: resolve => require(['@/' + component+'.vue'], resolve),
  161. // hidden:item.hidden,
  162. // //component:()=> import(`@/views/${item.component}.vue`),
  163. // meta: {
  164. // title:item.meta.title ,
  165. // icon: item.meta.icon,
  166. // url:item.meta.url ,
  167. // permissionList:item.meta.permissionList,
  168. // keepAlive:item.meta.keepAlive
  169. // }
  170. // }
  171. // if(item.alwaysShow){
  172. // menu.alwaysShow = true;
  173. // menu.redirect = menu.path;
  174. // }
  175. // if (item.children && item.children.length > 0) {
  176. // menu.children = [...generateChildRouters( item.children)];
  177. // }
  178. // //--update-begin----author:scott---date:20190320------for:根据后台菜单配置,判断是否路由菜单字段,动态选择是否生成路由(为了支持参数URL菜单)------
  179. // //判断是否生成路由
  180. // if(item.route && item.route === '0'){
  181. // //console.log(' 不生成路由 item.route: '+item.route);
  182. // //console.log(' 不生成路由 item.path: '+item.path);
  183. // }else{
  184. // routers.push(menu);
  185. // }
  186. // //--update-end----author:scott---date:20190320------for:根据后台菜单配置,判断是否路由菜单字段,动态选择是否生成路由(为了支持参数URL菜单)------
  187. // }
  188. // return routers
  189. // }
  190. /**
  191. * 深度克隆对象、数组
  192. * @param obj 被克隆的对象
  193. * @return 克隆后的对象
  194. */
  195. export function cloneObject(obj) {
  196. return JSON.parse(JSON.stringify(obj))
  197. }
  198. /**
  199. * 随机生成数字
  200. *
  201. * 示例:生成长度为 12 的随机数:randomNumber(12)
  202. * 示例:生成 3~23 之间的随机数:randomNumber(3, 23)
  203. *
  204. * @param1 最小值 | 长度
  205. * @param2 最大值
  206. * @return int 生成后的数字
  207. */
  208. export function randomNumber() {
  209. // 生成 最小值 到 最大值 区间的随机数
  210. const random = (min, max) => {
  211. return Math.floor(Math.random() * (max - min + 1) + min)
  212. }
  213. if (arguments.length === 1) {
  214. let [length] = arguments
  215. // 生成指定长度的随机数字,首位一定不是 0
  216. let nums = [...Array(length).keys()].map((i) => (i > 0 ? random(0, 9) : random(1, 9)))
  217. return parseInt(nums.join(''))
  218. } else if (arguments.length >= 2) {
  219. let [min, max] = arguments
  220. return random(min, max)
  221. } else {
  222. return Number.NaN
  223. }
  224. }
  225. /**
  226. * 随机生成字符串
  227. * @param length 字符串的长度
  228. * @param chats 可选字符串区间(只会生成传入的字符串中的字符)
  229. * @return string 生成的字符串
  230. */
  231. export function randomString(length, chats) {
  232. if (!length) length = 1
  233. if (!chats) chats = '0123456789qwertyuioplkjhgfdsazxcvbnm'
  234. let str = ''
  235. for (let i = 0; i < length; i++) {
  236. let num = randomNumber(0, chats.length - 1)
  237. str += chats[num]
  238. }
  239. return str
  240. }
  241. /**
  242. * 随机生成uuid
  243. * @return string 生成的uuid
  244. */
  245. export function randomUUID() {
  246. let chats = '0123456789abcdef'
  247. return randomString(32, chats)
  248. }
  249. /**
  250. * 下划线转驼峰
  251. * @param string
  252. * @returns {*}
  253. */
  254. export function underLine2CamelCase(string) {
  255. return string.replace(/_([a-z])/g, function (all, letter) {
  256. return letter.toUpperCase();
  257. });
  258. }
  259. /**
  260. * 判断是否显示办理按钮
  261. * @param bpmStatus
  262. * @returns {*}
  263. */
  264. export function showDealBtn(bpmStatus) {
  265. if (bpmStatus != "1" && bpmStatus != "3" && bpmStatus != "4") {
  266. return true;
  267. }
  268. return false;
  269. }
  270. /**
  271. * 增强CSS,可以在页面上输出全局css
  272. * @param css 要增强的css
  273. * @param id style标签的id,可以用来清除旧样式
  274. */
  275. export function cssExpand(css, id) {
  276. let style = document.createElement('style')
  277. style.type = "text/css"
  278. style.innerHTML = `@charset "UTF-8"; ${css}`
  279. // 清除旧样式
  280. if (id) {
  281. let $style = document.getElementById(id)
  282. if ($style != null) $style.outerHTML = ''
  283. style.id = id
  284. }
  285. // 应用新样式
  286. document.head.appendChild(style)
  287. }