JavaScript Math、数组、Date

Math

1. 写一个函数,返回从min到max之间的随机整数,包括min不包括max 。

function rand(min, max) {
    return parseInt(Math.random() * (max - min));
}
console.log(rand(3, 8));

2. 写一个函数,返回从min都max之间的随机整数,包括min包括max

function rand(min, max) {
   return parseInt(Math.random() * (max + 1 - min)) + min;
}
console.log(rand(3, 8));

3. 写一个函数,生成一个长度为 n 的随机字符串,字符串字符的取值范围包括0到9,a到 z,A到Z。

function getRandStr(len) {
    var res = "";
    var idex;
    var str = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
    for (var i = 0; i < len; i++) {
        idex = parseInt(Math.random() * str.length);
        res += str[idex];
    }
    return res;
}
var str = getRandStr(10);
var str2 = getRandStr(6);
console.log(str); //十位数的随机字符串
console.log(str2) //六位数的随机字符串

4. 写一个函数,生成五个随机 IP 地址,一个合法的 IP 地址为 0.0.0.0~255.255.255.255

function getRandIP() {
    var arr = [];
    for (var i = 0; i < 4; i++) {
        arr.push(parseInt(Math.random() * 256));
    }
    return arr.join(".");
}
for (let i = 0; i < 5; i++) {
    let ip = getRandIP()
    console.log(ip)
}

5. 写一个函数,生成一个随机颜色字符串,合法的颜色为#000000~ #ffffff

function getRandColor() {
    var arr = ["#"];
    var num;
    var str = "0123456789abcdef";
    for (var i = 0; i < 6; i++) {
        num = parseInt(Math.random() * str.length);
        arr.push(str[num]);
    }
    return arr.join("");
}
var color = getRandColor();
console.log(color);

数组

1. 数组方法里push、pop、shift、unshift、join、split分别是什么作用?

push:末位加上一个或多个元素,数组长度+1或+n;
pop:取出末位的一个元素,数组长度-1;
shift:取出首位的一个元素,数组长度-1;
unshift:首位加上一个或多个元素,数组长度+1或+n;
join:传入一个参数(缺省值为','),将按照该参数将数组连接成字符串;
split():方法将一个String对象分割成字符串数组,通过将字符串分成子串。

用 splice函数分别实现push、pop、shift、unshift方法

var arr = [1, 2, 3];

//push方法的实现
function functionPush(arr, element) {
    arr.splice(arr.length, 0, element);
    return arr;
}
console.log(functionPush(arr, 5));

//pop方法的实现
function functionPop(arr) {
    arr.splice(arr.length - 1, 1);
    return arr;
}
console.log(functionPop(arr));

//shift方法的实现
function functionUnshift(arr) {
    arr.splice(0, 1);
    return arr;
}
console.log(functionUnshift(arr));

 //unshift的实现方法
 function functionUnshift(arr, element) {
     arr.splice(0, 0, element);
     return arr;
 }
 console.log(functionUnshift(arr, 5));

2. 操作数组,数组中的每一项变为原来的平方,在原数组上操作

function squareArr(arr) {
    arr.forEach(function (e, i) {
        arr[i] = e * e;
    });
};
var arr = [2, 4, 6];
squareArr(arr);
console.log(arr); // [4, 16, 36]

3. 操作数组,返回一个新数组,新数组中只包含正数,原数组不变。

function filterPositive(arr) {
    return arr.filter(function (e) {
        return typeof e === 'number' && e > 0;
    });
};
var arr = [3, -1, 2, '高治东', '数组', true];
var newArr = filterPositive(arr);
console.log(newArr); //[3,2]

sort

var arr = [-4,1,3,18,12,22,9]
arr.sort()
console.log(arr)

var arr = [-4,1,3,18,12,22,9]
arr.sort(function(a,b){
 return a -b 
//return b-a
})
console.log(arr)

var students = [
  {name:'c',age:'14'},
  {name:'d',age:'11'},
  {name:'a',age:'12'},
  {name:'z',age:'20'},
  {name:'g',age:'7'},
]
//age排序
students.sort(function (s1, s2) {
    return s2.age - s1.age //从大到小
    //return s1.age - s2.age //从小到大
})
console.log(students)


//name排序
```bash
students.sort(function (s1, s2) {
    if (s1.name > s2.name) {
        return 1
    } else {
        return -1
    }
})
console.log(students)
/*[
  { name: 'a', age: '12' },
  { name: 'c', age: '14' },
  { name: 'd', age: '11' },
  { name: 'g', age: '7' },
  { name: 'z', age: '20' } 
]*/

Date

moment.js

var d = new Date()
console.log(d) // 当前的时间
typeof d //“object”
d.getDay() //星期几 //周日是0
d.getDate() //几号
d.getMoth() // 从0开始


var d2 = Date()
console.lgo(d2)//当前的时间的字符串
tyoeof d2  // "string"

1. 写一个函数getChIntv,获取从当前时间到指定日期的间隔时间。

function getChIntv(timestr) {
    var time = new Date(timestr).getTime() - 8 * 60 * 60 * 1000;
    var now = Date.now();
    var diff = time - now;
    var day = parseInt(diff / (1000 * 60 * 60 * 24));
    var hour = parseInt((diff % (1000 * 60 * 60 * 24)) / (60 * 60 * 1000));
    var minute = parseInt((diff % (1000 * 60 * 60)) / (60 * 1000));
    var second = parseInt((diff % (1000 * 60)) / (1000));
    return "距明天还有" + day + "天" + hour + "小时" + minute + "分" + second + "秒";
}
console.log(getChIntv("2017-03-24"));

2. 把hh-mm-dd格式数字日期改成中文日期

function getChsDate(timeStr) {
    var res = [];
    var dic = ['零', '一', '二', '三', '四', '五', '六', '七', '八', '九', '十', '十一', '十二', '十三', '十四', '十五', '十六', '十七', '十八', '十九', '二十', '二十一', '二十二', '二十三', '二十四', '二十五', '二十六', '二十七', '二十八', '二十九', '三十', '三十一'];
    var arr = timeStr.split('-'),
        year = arr[0],
        month = arr[1],
        day = arr[2];
    for (var i in year) {
        res.push(dic[year[i]]);
    }
    res.push('年');
    res.push(dic[parseInt(month)]);
    res.push('月');
    res.push(dic[parseInt(day)]);
    res.push('日');
    return res.join('');
}
var str = getChsDate('2017-03-23');
console.log(str); //二零一七年三月二十三日

3. 写一个函数,参数为时间对象毫秒数的字符串格式,返回值为字符串。假设参数为时间对象毫秒数t,根据t的时间分别返回如下字符串:

刚刚( t 距当前时间不到1分钟时间间隔)
3分钟前 (t距当前时间大于等于1分钟,小于1小时)
8小时前 (t 距离当前时间大于等于1小时,小于24小时)
3天前 (t 距离当前时间大于等于24小时,小于30天)
2个月前 (t 距离当前时间大于等于30天小于12个月)
8年前 (t 距离当前时间大于等于12个月)
function friendlyDate(time) {
    var now = Date.now();
    var offset = (now - parseInt(time)) / 1000 / 60;
    var result;
    if ((offset / 60 / 24 / 30 / 12) >= 1) {
        result = parseInt(offset / 60 / 24 / 30 / 12) + "年前";
    } else if ((offset / 60 / 24 / 30) >= 1) {
        result = parseInt(offset / 60 / 24 / 30) + "个月前";
    } else if ((offset / 60 / 24) >= 1) {
        result = parseInt(offset / 60 / 24) + "天前";
    } else if ((offset / 60) >= 1) {
        result = parseInt(offset / 60) + "小时前";
    } else if (offset >= 1) {
        result = parseInt(offset) + "分钟前";
    } else if (offset < 1) {
        result = "刚刚";
    }
    return result;
}
var str = friendlyDate('1484286699422') //  1分钟前
var str2 = friendlyDate('1483941245793') //4天前
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容