代码片段

# 代码片段

# POST 文件流下载文件

// urlencode编码解码
// 编码函数:encodeURIComponent()
// 解码函数:decodeURIComponent()

this.api
  .post(
    'record/export',
    { ...params },
    {
      responseType: 'blob',
    }
  )
  .then((response) => {
    // 下载excel
    let str = response.headers['content-disposition']
    let search = 'filename='
    var start = str.indexOf(search) //获得字符串的开始位置
    const URInfo = str.substring(start + search.length) //截取字符串获取url格式文件名
    const fileName = decodeURIComponent(URInfo) //url解码获取文件名

    const content = response.data
    const blob = new Blob([content])
    if ('download' in document.createElement('a')) {
      // 非IE下载
      const elink = document.createElement('a')
      elink.download = fileName
      elink.style.display = 'none'
      elink.href = URL.createObjectURL(blob)
      document.body.appendChild(elink)
      elink.click()
      URL.revokeObjectURL(elink.href) // 释放URL 对象
      document.body.removeChild(elink)
    } else {
      // IE10+下载
      navigator.msSaveBlob(blob, fileName)
    }
  })

# 地图坐标转换

国内各地图 API 坐标系统比较 国内地图坐标类型

// 火星坐标转百度坐标
function gcj02_to_bd09(lng, lat) {
  var z = Math.sqrt(lng * lng + lat * lat) + 0.00002 * Math.sin(lat * Math.PI)
  var theta = Math.atan2(lat, lng) + 0.000003 * Math.cos(lng * Math.PI)
  return { lng: z * Math.cos(theta) + 0.0065, lat: z * Math.sin(theta) + 0.006 }
}

// 百度坐标转火星坐标
function bd09_to_gcj02(lng, lat) {
  var x = lng - 0.0065,
    y = lat - 0.006
  var z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * Math.PI)
  var theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * Math.PI)
  return { lng: z * Math.cos(theta), lat: z * Math.sin(theta) }
}

// 获取两个坐标之间的距离
function GetDistance(lng1, lat1, lng2, lat2) {
  var radLat1 = (lat1 * Math.PI) / 180.0
  var radLat2 = (lat2 * Math.PI) / 180.0
  var a = radLat1 - radLat2
  var b = (lng1 * Math.PI) / 180.0 - (lng2 * Math.PI) / 180.0
  var s =
    2 *
    Math.asin(
      Math.sqrt(Math.pow(Math.sin(a / 2), 2) + Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2))
    )
  s = s * 6378.137 // 地球半径;
  s = Math.round(s * 10000) / 10000
  return s // 单位为km
}

# 文字超出隐藏

/*1. 单行超出隐藏 */
.xxx {
  width: 100%; /*宽度*/
  white-space: nowrap; /*超出的空白区域不换行*/
  overflow: hidden; /*超出隐藏*/
  text-overflow: ellipsis; /*文本超出显示省略号*/
}

/*2. 多行溢出隐藏显示...(在文字的容器上设置)  只兼容webkit内核的浏览器*/
.xxx {
  display: -webkit-box; /*将对象转为弹性盒模型展示*/
  -webkit-box-orient: vertical; /*设置弹性盒模型子元素的排列方式*/
  -webkit-line-clamp: 2; /*限制文本行数*/
  overflow: hidden; /*超出隐藏*/
}

/*3.多行溢出隐藏显示...(跨浏览器兼容+伪元素定位)*/
.xxx {
  position: relative;
  line-height: 1.4em; /*行高和height成倍数,这里以三行文本超出隐藏举例*/
  height: 4.2em;
  overflow: hidden;
}
.xxx::after {
  /*若要兼容IE8需用:after*/
  content: '...'; /*替换内容比较灵活*/
  position: absolute;
  bottom: 2px;
  right: 5px;
  padding: 0 3px;
  background: #fff; /*颜色和文字背景保持一致*/
  box-shadow: 0 0 10px #fff; /*边缘处理*/
}

# 禁止文本选中

/* pc */
.not-select{
  -moz-user-select:none;    /*火狐*/
  -webkit-user-select:none; /*webkit浏览器*/
  -ms-user-select:none;     /*IE10*/
  -khtml-user-select:none;  /*早期浏览器*/
  user-select:none;
}

/* wap */
.no-touch {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
/* js 禁止文本选中 */
ontouchstart="return false;"

# CSS 初始化

# web

@charset 'utf-8';

/* ===== 初始化样式 ===== */
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
button,
textarea,
p,
blockquote,
th,
td {
  margin: 0;
  padding: 0;
}
body {
  background: #fff;
  color: #555;
  font-size: 14px;
  font-family: Verdana, Arial, Helvetica, sans-serif;
}
td,
th,
caption {
  font-size: 14px;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: normal;
  font-size: 100%;
}
address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
  font-weight: normal;
}
a {
  color: #555;
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}
img {
  border: none;
}
ol,
ul,
li {
  list-style: none;
}
input,
textarea,
select,
button {
  font: 14px Verdana, Helvetica, Arial, sans-serif;
}
table {
  border-collapse: collapse;
}

/* ===== 公共样式 ===== */
/* 浮动 */
.fl {
  float: left;
}
.fr {
  float: right;
}
/* 清除浮动 */
.clearfix:after {
  content: '.';
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}
.clearfix {
  *zoom: 1;
}

/* 吸顶效果 */
.sticky {
  position: sticky;
  top: 0;
}

/* 单行文字超出显示... */
.ellipsis1 {
  /* 强制不换行 */
  white-space: nowrap;
  /* 文本超出省略 */
  text-overflow: ellipsis;
  overflow: hidden;
}

/* 多行文本超出隐藏 */
.ellipsis2 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  text-overflow: ellipsis;
  overflow: hidden;
}

# wap

@charset 'utf-8';

/* ===== 初始化样式 ===== */
body,
div,
ul,
li,
ol,
h1,
h2,
h3,
h4,
h5,
h6,
input,
textarea,
select,
p,
dl,
dt,
dd,
a,
img,
button,
form,
table,
th,
tr,
td,
tbody,
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  margin: 0;
  padding: 0;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
body {
  font: 12px/1.5 'Microsoft YaHei', '宋体', Tahoma, Arial, sans-serif;
  color: #555;
  background-color: #ffffff;
}
em,
i,
strong {
  font-style: normal;
}
a {
  text-decoration: none;
  color: #555;
  font-family: 'Microsoft YaHei', Tahoma, Arial, sans-serif;
}
/* 移动端点击a链接出现蓝色背景问题解决 */
a:link,
a:active,
a:visited,
a:hover {
  background: none;
  text-decoration: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}
ul,
ol {
  list-style: none;
}
li {
  list-style-type: none;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-family: 'Microsoft YaHei';
}
input {
  font-family: 'Microsoft YaHei';
}
/* 设置HTML5元素为块 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}
/* 图片自适应 */
img {
  width: 100%;
  height: auto;
  width: auto\9; /* ie8 */
  display: block;
  border: none;
  -ms-interpolation-mode: bicubic; /*为了照顾ie图片缩放失真*/
}
/* 禁用iPhone中Safari的字号自动调整 */
html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  /* 解决IOS默认滑动很卡的情况 */
  -webkit-overflow-scrolling: touch;
}
/* 禁止缩放表单 */
input[type='“submit”'],
input[type='“reset”'],
input[type='“button”'],
input {
  resize: none;
  border: none;
}

/* ===== 公共样式 ===== */

/* 浮动 */
.fl {
  float: left;
}
.fr {
  float: right;
}
/* 清除浮动 */
.clearfix:after {
  content: '.';
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}
.clearfix {
  *zoom: 1;
}

/* 吸顶效果 */
.sticky {
  position: sticky;
  top: 0;
}

/* 单行文字超出显示... */
.ellipsis1 {
  /* 强制不换行 */
  white-space: nowrap;
  /* 文本超出省略 */
  text-overflow: ellipsis;
  overflow: hidden;
}

/* 多行文本超出隐藏 */
.ellipsis2 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  text-overflow: ellipsis;
  overflow: hidden;
}

.db {
  display: block !important;
}
.dn {
  display: none;
}

# 一行背景代码

 {
  background: repeating-conic-gradient(#fff, #000, #fff 0.5deg);
}

css背景

# 修改全局滚动条样式

/* 修改全局滚动条样式 */
::-webkit-scrollbar {
    width: 5px; /* 纵向滚动条*/
    height: 5px; /* 横向滚动条 */
    background-color: #fff;
}

/*定义滚动条轨道 内阴影*/
::-webkit-scrollbar-track {
    box-shadow: inset 0 0 6px rgba(0, 0, 0, 0);
    background-color: #ccc;
}

/*定义滑块 内阴影*/
::-webkit-scrollbar-thumb {
    box-shadow: inset 0 0 6px rgba(0, 0, 0, 0);
    background-color: #1890ff; /* 配置为主色调 */
    border-radius: 10px;
}

# node获取本机ip

const os = require('os');

///获取本机ip///
function getIPAdress() {
    var interfaces = os.networkInterfaces();
    for (var devName in interfaces) {
        var iface = interfaces[devName];
        for (var i = 0; i < iface.length; i++) {
            var alias = iface[i];
            if (alias.family === 'IPv4' && alias.address !== '127.0.0.1' && !alias.internal) {
                return alias.address;
            }
        }
    }
}
const myHost = getIPAdress();

# 修改placeholder颜色

::-webkit-input-placeholder { /* WebKit browsers */
    color:    #999;
}
:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
    color:    #999;
}
::-moz-placeholder { /* Mozilla Firefox 19+ */
    color:    #999;
}
:-ms-input-placeholder { /* Internet Explorer 10+ */
    color:    #999;
}

# pre标签样式美化

pre {
  color:#444;
  margin:15px auto;
  padding:20px 15px;
  border:3px dashed #ddd;
  border-left:8px solid #bbb;
  background:#fff url('') repeat;
  white-space:pre-wrap;
  word-wrap:break-word;
  letter-spacing:1.5px;
  font:14px/25px '宋体', '新宋体', 'Comic Sans MS','courier new';
  line-height:22px;
  background-size:100% 44px;
}

pre样式美化

# 清除所有cookies

const clearCookie = () => {
  var keys = document.cookie.match(/[^ =;]+(?==)/g);
  if (keys) {
    for (var i = keys.length; i--; ) {
      document.cookie =
        keys[i] +
        "=0;expires=" +
        new Date(0).toUTCString() +
        ";max-age=0";
    }
  }
};

# js小数运算处理

解决js小数运算出现精度丢失问题

function floatMul(arg1, arg2) {
    let m = 0;
    const s1 = arg1.toString();
    const s2 = arg2.toString();
  
    try {
      m += s1.split(".")[1].length;
    } catch (e) {}
    try {
      m += s2.split(".")[1].length;
    } catch (e) {}
  
    return (Number(s1.replace(".", "")) * Number(s2.replace(".", ""))) / Math.pow(10, m);
  }
/**
 * 加法运算
 * @param a
 * @param b
 * @returns {Number}
 */
export function numberAdd(a, b) {
    let c, d, e
    if (undefined == a || a == null || a == '' || isNaN(a)) {
      a = 0
    }
    if (undefined == b || b == null || b == '' || isNaN(b)) {
      b = 0
    }
    try {
      c = a.toString().split('.')[1].length
    } catch (f) {
      c = 0
    }
    try {
      d = b.toString().split('.')[1].length
    } catch (f) {
      d = 0
    }
    e = Math.pow(10, Math.max(c, d))
    return (floatMul(a, e) + floatMul(b, e)) / e
  }
  /**
   * 减法运算
   * @param a
   * @param b
   * @returns {Number}
   */
  export function numberSub(a, b) {
    let c, d, e
    if (undefined == a || a == null || a == '' || isNaN(a)) {
      a = 0
    }
    if (undefined == b || b == null || b == '' || isNaN(b)) {
      b = 0
    }
    try {
      c = a.toString().split('.')[1].length
    } catch (f) {
      c = 0
    }
    try {
      d = b.toString().split('.')[1].length
    } catch (f) {
      d = 0
    }
    e = Math.pow(10, Math.max(c, d))
    return (floatMul(a, e) - floatMul(b, e)) / e
  }
  /**
   * 乘法运算
   * @param a
   * @param b
   * @returns {Number}
   */
  export function numberMul(a, b) {
    let c = 0
    let d = a.toString()
    let e = b.toString()
    try {
      c += d.split('.')[1].length
    } catch (f) {}
    try {
      c += e.split('.')[1].length
    } catch (f) {}
    return (Number(d.replace('.', '')) * Number(e.replace('.', ''))) / Math.pow(10, c)
  }
  /**
   * 除法运算
   * @param a
   * @param b
   * @returns
   */
  export function numberDiv(a, b) {
    let c, d
    let e = 0
    let f = 0
    try {
      e = a.toString().split('.')[1].length
    } catch (g) {}
    try {
      f = b.toString().split('.')[1].length
    } catch (g) {}
    // eslint-disable-next-line no-sequences
    return (c = Number(a.toString().replace('.', ''))), (d = Number(b.toString().replace('.', ''))), floatMul(c / d, Math.pow(10, f - e))
  }

# 金额

// 数字金额转中文金额
function changeNumMoneyToChinese(money) {
  var cnNums = new Array("零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"); //汉字的数字
  var cnIntRadice = new Array("", "拾", "佰", "仟"); //基本单位
  var cnIntUnits = new Array("", "万", "亿", "兆"); //对应整数部分扩展单位
  var cnDecUnits = new Array("角", "分", "毫", "厘"); //对应小数部分单位
  var cnInteger = "整"; //整数金额时后面跟的字符
  var cnIntLast = "元"; //整型完以后的单位
  var maxNum = 999999999999999.9999; //最大处理的数字
  var IntegerNum; //金额整数部分
  var DecimalNum; //金额小数部分
  var ChineseStr = ""; //输出的中文金额字符串
  var parts; //分离金额后用的数组,预定义
  var Symbol = ""; //正负值标记
  if (money == "") {
    return "";
  }

  money = parseFloat(money);
  if (money >= maxNum) {
    alert("超出最大处理数字");
    return "";
  }
  if (money == 0) {
    ChineseStr = cnNums[0] + cnIntLast + cnInteger;
    return ChineseStr;
  }
  if (money < 0) {
    money = -money;
    Symbol = "负 ";
  }
  money = money.toString(); //转换为字符串
  if (money.indexOf(".") == -1) {
    IntegerNum = money;
    DecimalNum = "";
  } else {
    parts = money.split(".");
    IntegerNum = parts[0];
    DecimalNum = parts[1].substr(0, 4);
  }
  if (parseInt(IntegerNum, 10) > 0) {
    //获取整型部分转换
    var zeroCount = 0;
    var IntLen = IntegerNum.length;
    for (var i = 0; i < IntLen; i++) {
      var n = IntegerNum.substr(i, 1);
      var p = IntLen - i - 1;
      var q = p / 4;
      var m = p % 4;
      if (n == "0") {
        zeroCount++;
      } else {
        if (zeroCount > 0) {
          ChineseStr += cnNums[0];
        }
        zeroCount = 0; //归零
        ChineseStr += cnNums[parseInt(n)] + cnIntRadice[m];
      }
      if (m == 0 && zeroCount < 4) {
        ChineseStr += cnIntUnits[q];
      }
    }
    ChineseStr += cnIntLast;
    //整型部分处理完毕
  }
  if (DecimalNum != "") {
    //小数部分
    var decLen = DecimalNum.length;
    for (var i = 0; i < decLen; i++) {
      var n = DecimalNum.substr(i, 1);
      if (n != "0") {
        ChineseStr += cnNums[Number(n)] + cnDecUnits[i];
      }
    }
  }
  if (ChineseStr == "") {
    ChineseStr += cnNums[0] + cnIntLast + cnInteger;
  } else if (DecimalNum == "") {
    ChineseStr += cnInteger;
  }
  ChineseStr = Symbol + ChineseStr;

  return ChineseStr;
}

// 千分位显示金额 sub是否加万
function formatPrice(price, sub) {
  price = price * 1.0 || 0;
  let fix = "";
  if (sub && price > 10000) {
    price = (price / 10000).toFixed(2);
    price = price * 1;
    fix = "万";
  }
  return (
    price.toLocaleString("zh-CN", {
      style: "currency",
      currency: "CNY",
    }) + fix
  ); //¥999,999.00
  return String(price).replace(/\B(?=(\d{3})+(?!\d))/g, ",");
}

# 日期时间格式化

/**
 * 日期时间格式化
 * @param type y:年;ym:年月;ymd:年月日;ymdh:年月日时;ymdhf:年月日时分;ymdhfs:年月日时分秒
 * @param style 1:y-m-d h:m:s  2:y年m月。。。
 * @returns {string}
 */
function getDateFormat(date, type, style) {
  type = type || "ymdhfs";
  style = style || 1;
  var now = date ? new Date(date) : new Date();
  var year = now.getFullYear(); //得到年份
  var month = now.getMonth(); //得到月份
  var date = now.getDate(); //得到日期
  var day = now.getDay(); //得到周几
  var hour = now.getHours(); //得到小时
  var minu = now.getMinutes(); //得到分钟
  var sec = now.getSeconds(); //得到秒
  var MS = now.getMilliseconds(); //获取毫秒
  var week;
  month = month + 1;
  if (month < 10) month = "0" + month;
  if (date < 10) date = "0" + date;
  if (hour < 10) hour = "0" + hour;
  if (minu < 10) minu = "0" + minu;
  if (sec < 10) sec = "0" + sec;
  // if (MS < 10) MS = "0" + MS;
  // var arr_week = new Array("星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六");
  // week = arr_week[day];
  var time = [];
  type.indexOf("y") != -1 ? time.push(year + (style == 1 ? "-" : "年")) : null;
  type.indexOf("m") != -1 ? time.push(month + (style == 1 ? "-" : "月")) : null;
  type.indexOf("d") != -1 ? time.push(date + (style == 1 ? " " : "日")) : null;
  type.indexOf("h") != -1 ? time.push(hour + (style == 1 ? ":" : "时")) : null;
  type.indexOf("f") != -1 ? time.push(minu + (style == 1 ? (type.indexOf("s") != -1 ? ":" : "") : "分")) : null;
  type.indexOf("s") != -1 ? time.push(sec + (style == 1 ? "" : "秒")) : null;
   
  // time = year + "-" + month + "-" + date + " " + hour + ":" + minu + ":" + sec;
  return time.join("").trim().replace(/-+$/g, "");
}

# 数组转树形

/**
 * 转树形数组
 * @param {*} arr
 * @param {*} pid 父级数据id
 * @param {*} id 当前数据id
 * @returns
 */
async function arrToTreeArr(arr = [], pid = "pId", id = "id") {
  var treeArr = [];
  arr.forEach(async (val, i) => {
    var _val = getObjByField(arr, id, val[pid]);
    if (!_val) {
      //无上级
      val.children = await getChildren(getObjArrByField(arr, pid, val[id]), true);
      treeArr.push(val);
    }
  });

  function getChildren(children = [], first) {
    children.forEach((val, i) => {
      val.children = getObjArrByField(arr, pid, val[id]);
      if (val.children.length) getChildren(val.children);
    });
    if (first) return children;
  }
  return treeArr;
}