My Javascript Snippets

對象排序

function sortObject(obj, recursive, sortFunc) {
  const result = {}
  Object.keys(obj).sort(sortFunc).forEach(key=>{
    const curValue = obj[key]
    if(recursive && Object.prototype.toString.call(curValue) === "[object Object]"){
      result[key] = sortObject(curValue,recursive,sortFunc)
    }else{
      result[key] = curValue
    }
  })
  return result;
}

帶 Progress 的 Promise.all

function promiseAll(promises) {
  let finishedCount = 0
  let progressCb = () => {}
  const promisesLength = promises.length
  const results = new Array(promisesLength)
  const result = new Promise(function(resolve, reject) {
    promises.forEach((val, idx) => {
      Promise.resolve(val).then(
        function(res) {
          finishedCount++
          results[idx] = res
          progressCb(finishedCount, results)
          if (finishedCount === promisesLength) {
            return resolve(results)
          }
        },
        function(err) {
          return reject(err)
        },
      )
    })
  })
  result.progress = cb => {
    progressCb = cb
    return result
  }
  return result
}

// 用法
Promise.prototype.all = promiseAll
var p1 = Promise.resolve(1)
var p2 = Promise.resolve(2)
var p3 = Promise.resolve(3)
Promise.all([p1, p2, p3])
  .progress((i, j) => {
    console.log(i, j)
  })
  .then(function(results) {
    console.log(results) // [1, 2, 3]
  })

計算個稅

/**
 * 計算個稅
 * @param taxableIncome {number} 0 需繳稅的收入(扣除五險一金等)
 * @param startLine {number} 5000 起徵點
 * @return {afterTax, tax} 稅和繳稅後的收入
 */
function calTax(taxableIncome = 0, startLine = 5000) {
  // configs
  const levels = [0, 3000, 12000, 25000, 35000, 55000, 80000];
  const taxRates = [0, 0.03, 0.1, 0.2, 0.25, 0.3, 0.35, 0.45];
  const deductions = [0, 0, 105, 555, 1005, 2755, 5505, 13505];

  const toBeTaxedIncome = taxableIncome - startLine;
  const levelIdx = levels.findIndex(level => level > toBeTaxedIncome);
  const tax = toBeTaxedIncome * taxRates[levelIdx] - deductions[levelIdx];
  const afterTax = taxableIncome - tax;
  return { afterTax, tax };
}

計算五險一金

/**
 * 計算五險一金
 * @param income {number} 0 收入
 * @param maxBase {number} 21400 最高基數,根據不一樣地方來改變,此爲上海市
 * @return {myFees, cFees} {Array,Array} 分別是本身的繳費和公司的繳費,數組各元素分別表明:
 *          myFees: [總共 養老 醫療 失業 公積金]
 *          cFees:  [總共 養老 醫療 失業 公積金 工傷 生育]
 */
function calInsurances(income, maxBase = 19512) {
  // configs
  // 個人費率:養老 醫療 失業 公積金
  const myRates = [0.08, 0.02, 0.005, 0.07];
  // 公司費率:養老 醫療 失業 公積金 工傷 生育
  const cRates = [0.2, 0.1, 0.005, 0.07, 0.003, 0.01];

  // 添加總費率
  myRates.unshift(
    myRates.reduce((totalRate, curRate) => totalRate + curRate, 0)
  );
  cRates.unshift(cRates.reduce((totalRate, curRate) => totalRate + curRate, 0));
  const base = Math.min(income, maxBase);
  const myFees = myRates.map(rate => (base * rate).toFixed(2));
  const cFees = cRates.map(rate => (base * rate).toFixed(2));
  return { myFees, cFees };
}
相關文章
相關標籤/搜索