gan货大全

1.将excel文件中的日期格式的内容转回成标准时间

// 把excel文件中的日期格式的内容转回成标准时间
export function formatExcelDate(numb, format = '/') {
  const time = new Date((numb - 25567) * 24 * 3600000 - 5 * 60 * 1000 - 43 * 1000 - 24 * 3600000 - 8 * 3600000)
  time.setYear(time.getFullYear())
  const year = time.getFullYear() + ''
  const month = time.getMonth() + 1 + ''
  const date = time.getDate() + ''
  if (format && format.length === 1) {
    return year + format + month + format + date
  }
  return year + (month < 10 ? '0' + month : month) + (date < 10 ? '0' + date : date)
}

2.中文key转为英文key

后端需要的数据是这样的格式的 

[{'姓名':'小张', '手机号': '13712345678'}{.....}]

 我们需要将他转换为

[ {'username':'小张','mobile': '13712345678'}, {.....} ]

思路:

1.定义一个数据对象 key是中文 value是英文  我们只需要对象[中文]就额可以拿到对象中的英 文value  例如 :{username:"姓名"}

2.使用Object.keys拿到么一个数组中所有的key属性 ---中文key

3.使用map循环数组  数组里面有几项就转换成几个 返回的是一个数组  

4.在map定义空对象 之后循环中文key的每一项来处理每一个数据

5.给空对象的英文key进行赋值 数组里的每一项的中文key

代码如下

 format(result, header) {
      const mapInfo = {
        '入职日期': 'timeOfEntry',
        '手机号': 'mobile',
        '姓名': 'username',
        '转正日期': 'correctionTime',
        '工号': 'workNumber',
        '部门': 'departmentName',
        '聘用形式': 'formOfEmployment'
      }
       const arr = result.map(it => {
        const enobj = {}
        header.forEach(zhkey => {
          const enkey = mapInfo[zhkey]
          if (enkey === 'timeOfEntry' || enkey === 'correctionTime') {
            enobj[enkey] = new Date(formatExcelDate(it[zhkey]))
          } else {
            enobj[enkey] = it[zhkey]
          }
        })
        arr.push(enobj)
      })
      return arr
    },

3.英文key转化为中文key

  formatData(list) {
      const map = {
        'id': '编号',
        'password': '密码',
        'mobile': '手机号',
        'username': '姓名',
        'timeOfEntry': '入职日期',
        'formOfEmployment': '聘用形式',
        'correctionTime': '转正日期',
        'workNumber': '工号',
        'departmentName': '部门',
        'staffPhoto': '头像地址'
      }
      console.log(list)
      let header = []
      // header = ['id', 'mobile', 'username', .....]
      // data = [
      //     ['65c2', '1380000002', '管理员', ....],
      //     ['65c3', '1380000003', '孙财', ....],
      // ]
      let data = []
      // 开始代码
      // 找到一个元素
      const one = list[0]
      if (!one) {
        return { header, data }
      }
      header = Object.keys(one).map(key => {
        return map[key]
      })

      // data把list中每一个对象转成 对应的value数组
      data = list.map(obj1 => {
        // 把  Obj['formOfEmployment']: 1 , 2   ---> '正式', '非正式'
        const key = obj1['formOfEmployment'] // 1, 2
        obj1['formOfEmployment'] = obj[key] // hireTypEnmu:{1:'正式', '2':'非正式' }

        return Object.values(obj1)
      })

      return { header, data }
    },

4.数组转换为树形

4-1递归形式实现


    <script>
            let arr=[
            { 'id': '29', 'pid': '',     'name': '总裁办' },
            { 'id': '2c', 'pid': '',     'name': '财务部' },
            { 'id': '2d', 'pid': '2c', 'name': '财务核算部'},
            { 'id': '2f', 'pid': '2c', 'name': '薪资管理部'},
            { 'id': 'd2', 'pid': '',     'name': '技术部'},
            { 'id': 'd3', 'pid': 'd2', 'name': 'Java研发部'}
            ]
         function tranListToTreeData(list,pid='') {
           // 先找到所有的根节点
           let tranList=list.filter(it=>it.pid===pid)
           tranList.forEach(itm =>{
            //传入id  list进行递归 在筛选出 他的父级 是一个数组
             itm.children=tranListToTreeData(list,itm.id)
           })
           return tranList
        }
        
        console.log(tranListToTreeData(arr));

4-2 非递归方式实现
 


// 数组转换为树形的函数

export function tranListToTreeData(list) {
  // 最终要产出的树状数据的数组
  const treeList = []
  // 所有项都使用对象存储起来
  const map = {}

  // 建立一个映射关系:通过id快速找到对应的元素
  list.forEach(item => {
    if (!item.children) {
      item.children = []
    }
    map[item.id] = item
  })
  // map:
  // {
  //   "312c": { 'id': '312c', 'pid': '',     'name': '财务部',    children: [{ 'id': '312d', 'pid': '312c', 'name': '财务核算部',children: []}] },
  //   "312d": { 'id': '312d', 'pid': '312c', 'name': '财务核算部',children: []}
  // }

  list.forEach(item => {
    // 对于每一个元素来说,先找它的上级
    //    如果能找到,说明它有上级,则要把它添加到上级的children中去
    //    如果找不到,说明它没有上级,直接添加到 treeList
    const parent = map[item.pid]
    // 如果存在则表示item不是最顶层的数据
    if (parent) {
      parent.children.push(item)
    } else {
      // 如果不存在 则是顶层数据
      treeList.push(item)
    }
  })
  // 返回出去
  return treeList
}

5.重置路由

export function resetRouter() {
  const newRouter = createRouter()
  router.matcher = newRouter.matcher // reset router
}

6.定时器(手机验证码、5秒跳转都适用)

import { useEffect, useRef, useState } from 'react'
export default function useCountDown (initCount = 10, callBack) {
  // 存入到useRef中
  const refTimer = useRef()
  /* 用户可以定义:
     1.倒计时的时间
     2.倒计时结束的动作
     3.何时开始倒计时
     */
  // 1. 初始化倒计时的时间
  const [count, setCount] = useState(initCount)
  // 2.开启定时器
  const start = () => {
    setCount(initCount)
    refTimer.current = setInterval(() => {
      setCount((count) => count - 1)
    }, 1000)
  }
  // 2.倒计时结束做的事情
  useEffect(
    () => {
      if (count === 0) {
        clearInterval(refTimer.current)
        callBack()
      }
    },
    [count]
  )
  // 3.组件销毁之前清掉定时器
  useEffect(() => {
    return () => {
      clearInterval(refTimer.current)
    }
  }, [])
  //  3.最后会返回给用户一个倒计时的时间和何时开始倒计时
  return {
    count,
    start
  }
}

5.axios的基础封装

import axios from 'axios'
// 配置全局基地址 和请求超时时间
const instance = axios.create({
  baseURL: 'http://geek.itheima.net/v1_0/',
  timeout: 5000
})

/**
 * 请求拦截器
 * 1.可以每次发请求之前携带请求头
 * **/
instance.interceptors.request.use(
  function (config) {
    return config
  },
  function (error) {
    return Promise.reject(error)
  }
)

/**
 * 请求拦截器
 * 1.axios每次返回的数据会多包裹一层对象 返回数据时我们可以直接在响应拦截器中将data return出去
 * 2.token失效可以进行处理,token失效在响应拦截器捕获错误 为401
 * 4.断网情况:response的值为undefined可以进行判断然后提示用户网络超时
 * **/
instance.interceptors.response.use(
  function (response) {
    return response.data
  },
  function (error) {
    return Promise.reject(error)
  }
)

export default instance

6.本地存入token,获取token等操作

const TOKEN = 'token'
// 1.获取token 传入token名
export const getToken = () => {
  return localStorage.getItem(TOKEN)
}

// 2.设置token 传入token名
export const setToken = (token) => {
  localStorage.setItem(TOKEN, token)
}

// 3.删除token
export const removeToken = () => {
  localStorage.removeItem(TOKEN)
}

// 4. 判断是否拥有token 返回一个布尔值
export const hasToken = () => {
  return !!getToken()
}

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值