前端项目工具函数整理

// 获取cookie
export function getCookie (cname) {
  const name = `${cname}=`;
  const ca = document.cookie.split(';');
  for (let i = 0; i < ca.length; i++) {
    const c = ca[i].trim();
    if (c.indexOf(name) === 0) return c.substring(name.length, c.length);
  }
  return '';
}

/**
 * 获取一组随机数2,主要解决key重复的请
 */
export const keyGuid = () => 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {
  const r = (Math.random() * 16) | 0;
  // eslint-disable-next-line eqeqeq
  const v = c == 'x' ? r : (r & 0x3) | 0x8;
  return v.toString(16);
});

/**
 * 获取一组随机数2
 * 可以很好地解决key重复的问题
 */
export const keyGuid2 = () => {
  function S4 () {
    return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1);
  }
  return `${S4() + S4()}-${S4()}-${S4()}-${S4()}-${S4()}${S4()}${S4()}`;
};

// 获取当前路径下?后边的值
export const getQueryString = (name) => {
  const reg = new RegExp(`(^|&)${name}=([^&]*)(&|$)`);
  const index = window.location.href.indexOf('?');
  const r = window.location.href.substr(index + 1).match(reg);
  if (r) return decodeURIComponent(r[2]);
  return null;
};

// 获取当前路径下?后边的值写法2
export const getQueryString2 = (name) => {
  const temp = window.location.href.split('?');
  const params = temp[1];
  const keyValue = params.split('&');
  const paramObj = {};
  for (let i = 0; i < keyValue.length; i++) {
    const item = keyValue[i].split('=');
    const key = item[0];
    const value = item[1];
    paramObj[key] = decodeURIComponent(value);
  }
  return paramObj[name] || null;
}

/**
 * 封装一下跳转函数
 * 直接使用,window.location.href='xxxx.html',在某些情况下会出现白屏的情况
 * @param { 需要跳转的链接 } url
 */
export const handleJumpLink = (url) => {
  window.history.pushState({}, '', url);
}

/**
 * 数组去重
 * @param {*数组} songs
 */
export function arrayUnique (songs) {
  const result = {};
  const finalResult = [];
  for (let i = songs.length - 1; i >= 0; i--) {
    result[songs[i].name] = songs[i];
  }
  Object.keys(result).map((item) => finalResult.push(result[item]));
  return finalResult;
}

/**
 * 数组去重
 * @param { 数组 } arr
 * @returns 去重后函数
 */
export const arrayUnique2 = (arr) => {
  if (!Array.isArray(arr)) {
    return;
  }
  const array = [];
  for (let i = 0; i < arr.length; i++) {
    if (array.indexOf(arr[i]) === -1) {
      array.push(arr[i]);
    }
  }
  return array;
};

/**
 * 数组对象去重
 * @param { 原始array数据 } dataList
 * @param { 根据这个key来进行去重 } key
 * @returns
 */
export function arrayObjUnique(dataList, key) {
  return dataList.filter((element, index, self) => {
    return self.findIndex(x => x[key] === element[key]) === index
  })
}

/**
 * 数组对象去重
 * @param { 原始array数据 } dataList
 * @param { 根据这个key来进行去重 } key
 * @returns
 */
export function arrayObjUnique2(dataList, key) {
  let hasObj = {}
  return dataList.reduce((cur, next) => {
    hasObj[next[key]] ? '' : (hasObj[next[key]] = true && cur.push(next))
    return cur
  }, [])
}



/**
 * @param { 时间戳 } result
 * @returns 时间戳转换输出xx天xx小时xx分xx秒
 */
export const formatSeconds = function (result) {
  const d = Math.floor(result / (60 * 60 * 24));
  const h = Math.floor((result % (60 * 60 * 24)) / (60 * 60));
  const m = Math.floor((result % (60 * 60)) / 60);
  const s = Math.floor(result % 60);
  if (d && h && m && s) {
    return `${d}${'天'}${h}${'小时'}${m}${'分'}${s}${'秒'}`;
  }
  if (h && m && s) {
    return `${h}${'小时'}${m}${'分'}${s}${'秒'}`;
  }
  if (m && s) {
    return `${m}${'分'}${s}${'秒'}`;
  }
  if (s) {
    return `${s}${'秒'}`;
  }
  return '-';
};

/**
 * 获取 blob
 * @param  {String} url 目标文件地址
 * @return {cb}
 */
export function getBlob (url, cb) {
  var xhr = new XMLHttpRequest();
  xhr.open('GET', url, true);
  xhr.responseType = 'blob';
  xhr.onload = function () {
    if (xhr.status === 200) {
      cb(xhr.response);
    }
  };
  xhr.send();
}

/**
* 保存
* @param  {Blob} blob
* @param  {String} filename 想要保存的文件名称
*/
function saveAs (blob, filename) {
  if (window.navigator.msSaveOrOpenBlob) {
    navigator.msSaveBlob(blob, filename);
  } else {
    var link = document.createElement('a');
    var body = document.querySelector('body');
    link.href = window.URL.createObjectURL(blob);
    link.download = filename;
    // fix Firefox
    link.style.display = 'none';
    body.appendChild(link);
    link.click();
    body.removeChild(link);
    window.URL.revokeObjectURL(link.href);
  };
}

/**
* 下载
* @param  {String} url 目标文件地址
* @param  {String} filename 想要保存的文件名称
*/
export function download (url, filename) {
  getBlob(url, function (blob) {
    saveAs(blob, filename);
  });
};

/**
 * 获取前端静态资源文件夹下的所有文件
 * @param { 文件路径,一般是静态资源文件static下 } filePath
 * @param { 某种文件.md,.png,.text,写法参考 /\.md$/ } fileExp
 * @returns 获取所有符合规则文件名
 */
export const loadAllFile = function (filePath, fileExp) {
  const filesMD = require.context(filePath, true, fileExp);
  return filesMD.keys();
};

/**
 * 自定义排序
 * @param { 排序key,目前支持数字 } objKey
 * @param { 升序 asc | 降序 desc } order
 * @returns
 */
export function sortDiy (objKey, order = 'asc') {
  return function (obj1, obj2) {
    let val1 = obj1[objKey];
    let val2 = obj2[objKey];
    if (!isNaN(Number(val1)) && !isNaN(Number(val2))) {
      val1 = Number(val1);
      val2 = Number(val2);
    }
    if (val1 < val2) {
      return order === 'asc' ? -1 : 1;
    }
    if (val1 > val2) {
      return order === 'asc' ? 1 : -1;
    }
    return 0;
  };
}

/**
 * 自定义排序
 * @param { 排序key,目前支持时间 } objKey
 * @param { 升序 asc | 降序 desc } order
 * @returns
 */
export function sortDiyTime (objKey, order = 'asc') {
  return function (obj1, obj2) {
    const val1 = obj1[objKey];
    const val2 = obj2[objKey];
    if (Date.parse(val1) < Date.parse(val2)) {
      return order === 'asc' ? -1 : 1;
    }
    if (Date.parse(val1) > Date.parse(val2)) {
      return order === 'asc' ? 1 : -1;
    }
    return 0;
  };
};

/**
 * 字符串倒叙输出
 */
export function flashback (val) {
  return val.split('').reverse().join('');
};
// 例如下面这个字符串,取第一个“-”符号后面的值
'gb28181-sip-service-edge-node-zone'.match(/-(\S*)/)[1];
 

 

posted on 2022-05-25 16:14  忘忧很努力呀~  阅读(63)  评论(0编辑  收藏  举报