1、千分位分隔符

const toDecimalMark = num => num.toLocaleString("en-US");
console.log(toDecimalMark(12305030388.9087))

2、时间戳转时间

const setTime = tiemStamp => new Date(parseInt(timeStamp) * 1000).toLocaleString().replace(/[/]/g,'-');
console.log(setTime(1535932800))

3、时间转时间戳

const timeStamp = time => new Date(time).getTime();
console.log(timeStamp('2019-03-19 11:55:00'))

4、去除空格

const removeSpace = str => str.replace(/\s+/g,'')
let str = '1 2 3 4'
console.log(removeSpace(str))

5、检测类型

const typeOf = str=> Object.prototype.toString.call(str) == '[object String]'
let str = '3123'
console.log(typeOf(str))

6、数字简化为“万”

function unitConvert(num){
let moneyUnits = ['元','万元','亿元','万亿'];
let dividend = 10000;
let curentNum = num; //转换数字
let curentUnit = moneyUnits[0]; //转换单位
let len = moneyUnits.length;
for(var i = 0; i < len; i++) {
curentUnit = moneyUnits[i];
if(strNumSize(curentNum) < 5) {
break;
}
curentNum = curentNum / dividend;
}
let m = {num: 0,unit: ""}
m.num = curentNum.toFixed(2);
m.unit = curentUnit;
return m;
}
function strNumSize(tempNum) {
var stringNum = tempNum.toString();
var index = stringNum.indexOf(".");
var newNum = stringNum;
if(index != -1) {
newNum = stringNum.substring(0, index);
}
return newNum.length;
}
unitConvert(1000000)

7、数组去重

(1)
let arrList = [1,2,3,1,3,33,6,2];
const removeRepeat = arr => [...new Set(arr)]
console.log(removeArr(arrList))
(2)
let arrList = [1,2,3,1,3,33,6,2];
let newArr = [];
let len = arrList.length
for(let i=0;i<len;i++){
newArr.indexOf(arrList[i])==-1 ? newArr.push(arrList[i]):''
}
console.log(newArr)

8、出现最多次数的字符串,出现多少次

let str = "qwertyuiopqqqasdf"
function maxstringload(str){
let obj = {}
let len = str.length
for(let i=0;i<str.len;i++){
let key = str[i]
if(obj[key]){
obj[key]++
}else{
obj[key] = 1
}
}
let maxCount =0;
let maxString = "";
for(let key in obj){
if(maxCount<obj[key]){
maxCount = boj[key];
maxString = key;
}
}
return "出现次数最多的字母:" + maxString + "出现了" + maxCount + "次";
}
console.log(maxstringload(str))

9、数组排序

(1)
let arr = [17,2,47,3,5,9,3,4,11,4,24]
const sortArr = arr => arr.sort((prve,next) => prve-next);
console.log(arr) (2)
function bubbleSort(arr) {
let len = arr.length;
for(let i = 0; i < len; i++) {
for(let j = 0; j < len - 1 - i; j++) {
if(arr[j] > arr[j + 1]) { //相邻元素两两对比,如果前一个数比后一个大,就交换位置
let temp = arr[j + 1]; //元素交换
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
}
return arr;
}
let arr = [3, 44, 38, 5, 47, 15, 36, 26, 27, 2, 46, 4, 19, 50, 48];
console.log(bubbleSort(arr));

10、深拷贝

(1)
const clone = obj => obj.JSON.parse(JSON.stringify(obj));
const clone = obj => obj.JSON.stringify(JSON.parse(obj))

(2)
const perfectClone = obj => {
if(obj == null){
return 'unKonwn';
}
if(typeof obj !== 'object'){
return obj
}
if(obj.constructor === Date){
return new Date(obj)
}
const newObj = new obj.constructor();
for(let key in obj){
if(obj.hasOwnProperty(key)){
const val = obj[key]
newObj[key] = typeof val === 'object' ? argument.call(val) : val;
}
}
return newObj
}

11、浅拷贝

const shallowClone = obj => Object.assign({},obj)

12、随机数

Math.random();//随机生成0到1的数字

Math.floor(Math.random() * 可能只的总数 + 第一个可能的值)

eg:Math.floor(Math.random() * 9 + 2); // 生成2到10的值,包括2和10
即:
Math.floor(Math.random()*(最大值 - 最小值 +1) + 最小值);//随机生成[n,m]的随机整数

  

13、数组扁平化

function flat(arr){
let newArr = [];
let len = arr.length
for(let i=0;i<len;i++){
if (Array.isArray(arr[i])) {
newArr = newArr.concat(flat(arr[i]));
}else{
newArr.push(arr[i])
}
   }
return newArr
}
let arr = [1,2,[3,4,[5,6],7],8,9];
console.log(flat(arr))

待续。。。

js小仓库的更多相关文章

  1. js小功能整理

    /** * 判断是否包含字符串某字符串 * @param {[type]} str [被检测的字符串] * @param {[type]} substr [检测是否含有的字符串] * @return ...

  2. [转载]Js小技巧||给input type=“password”的输入框赋默认值

    http://www.cnblogs.com/Raywang80s/archive/2012/12/06/2804459.html [转载]Js小技巧||给input type="passw ...

  3. 一些js小题(一)

    一些js小题,掌握这些对于一些常见的面试.笔试题应该很有帮助: var a=10; function aa(){ alert(a); } function bb(){ aa(); } bb();//1 ...

  4. 第24篇 js小知识和“坑”

    前面说了说了js的相关知识,基本上除了语法外,把项目常用的知识做了一个梳理,现在说下js的其它方面的知识,这些知识不成体系,属于不理解对于一般开发没什么太多影响,但如果理解清楚,可以更好去开发. js ...

  5. React.js 小书介绍

    React.js 小书 Github 关于作者 这是一本关于 React.js 的小书. 因为工作中一直在使用 React.js,也一直以来想总结一下自己关于 React.js 的一些知识.经验.于是 ...

  6. 一个js小游戏----总结

    花了大概一天左右的功夫实现了一个js小游戏的基本功能,类似于“雷电”那样的小游戏,实现了随即怪物发生器,碰撞检测,运动等等都实现了,下一个功能是子弹轨迹,还有其他一些扩展功能,没有用库,也没有用web ...

  7. React.js小书总结

    (迁移自旧博客2017 08 27) 第一阶段 react的组件相当于MVC里面的View. react.js 将帮助我们将界面分成了各个独立的小块,每一个块就是组件,这些组件之间可以组合.嵌套,就成 ...

  8. js小技巧总结

    js小技巧总结 1.Array.includes条件判断 function test(fruit) { const redFruits = ["apple", "stra ...

  9. JS小积累(二)— 自动获取浏览器尺寸

    JS小积累-获取浏览器窗口尺寸 作者: 狐狸家的鱼 GitHub:八至 autodivheight(); function autodivheight() { //函数:获取尺寸 //获取浏览器窗口高 ...

随机推荐

  1. 大前端涉猎之前后端交互总结2:使用PHP进行表单数据上传与更新

    1:使用PHP进行表单上传 1.1 form表单的数据收集 HTML页面: 代码解释:核心模块是form的属性: --提交方式 :  method="post" --指定 name ...

  2. python传递任意数量的实参

    1.传递任意的实参 def make(*test):#带*号 print(test) make("one")#传递一个实参 make("one","t ...

  3. 编写高质量代码改善C#程序的157个建议——建议153:若抛出异常,则必须要注释

    建议153:若抛出异常,则必须要注释 有一种必须加注释的场景,即使异常.如果API抛出异常,则必须给出注释.调用者必须通过注释才能知道如何处理那些专有的异常.通常,即便良好的命名也不可能告诉我们方法会 ...

  4. Eclipse下配置主题颜色

    插件地址  http://eclipse-color-theme.github.com/update 安装之后 下载安装好之后,点击window -> preferences -> Gen ...

  5. Class Loading Deadlocks

    By tomas.nilsson on Feb 28, 2010 Mattis keeps going strong, in this installment you get to learn eve ...

  6. ARM汇编中一些重要伪指令

    IMPORT ,定义表示这是一个外部变量的标号,不是在本程序定义的 EXPORT ,表示本程序里面用到的变量提供给其他模块调用的. 以上两个在汇编和C语言混合编程的时候用到 ENDP    表示PRO ...

  7. Mysql主主复制+keepalived

    1>环境 Master1 10.0.0.201 Master2 10.0.0.202 2>Master1操作授权 mysql>grant replication slave on * ...

  8. Linq分组操作之GroupBy,GroupJoin扩展方法源码分析

    Linq分组操作之GroupBy,GroupJoin扩展方法源码分析 一. GroupBy 解释: 根据指定的键选择器函数对序列中的元素进行分组,并且从每个组及其键中创建结果值. 查询表达式: var ...

  9. ecahrt 扇形(半扇形)

    var data = [{ "name": "1", "value": 54 }, { "name": "2& ...

  10. CentOS关机命令

    Linux centos关机与重启命令详解与实战 Linux centos重启命令: 1.reboot 2.shutdown -r now 立刻重启(root用户使用) 3.shutdown -r 1 ...