⑱Math、数组、Date

一、Math

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

function intNum(min,max){
    return Math.floor(Math.random()*(max-min)+min)
}

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

function intNum(min,max){
    return Math.floor(Math.random()*(max-min+1)+min)
}

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

function genAStr(length){
    var i,str=''
    for(i=0;i<length;i++){
        str += dict[Math.floor(Math.random()*dict.length)]
    }
    return str
}

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

function getRandIP(){
  var str=[]
  for(var i=0;i<4;i++){
    str[i]=Math.floor(Math.random()*256)
  }
  return str.join(',')
}
var ip = getRandIP()
console.log(ip)

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

dict ='abcdef0123456789'
function getRandColor(){
    var c='#'
    for(var i=0;i<6;i++){
        c+=dict[Math.floor(Math.random()*dict.length)]
    }
    return c
}
var color = getRandColor()
console.log(color)   // #3e2f1b

二、数组

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

//push()接收任意数量的参数,将它们逐个添加到数组末尾,并返回修改后数组的长度
var a = [1,2]
a.push(3,4)
console.log(a)  //[1,2,3,4]
//pop()移除数组最后一项,减少数组的length值,并返回移除的项
var b = [1,2]
b.pop()
console.log(b)  //[1]
console.log(b.length) //1
//shift()移除数组的第一项并返回该项,同时数组长度减1
var c = [1,2]
c.shift()
console.log(c) //[2]
console.log(c.length) //1
//unshift()接收任意数量参数,添加到数组开头,并返回新数组长度
var d = [1,2]
d.unshift(3,4)
console.log(d) //[3,4,1,2]
//join() 方法用于把数组中的所有元素放入一个字符串,元素通过指定的分隔符分隔
var e = [1,2,'a']
console.log(e.join('')) //'12a'
//splice(index,howmany,item1,.....,itemX)用来对数组进行多种操作,index规定添加/删除的位置,为负数则在结尾添加;howmany规定要删除的数量,为0则不删除;item1~itemX为添加项,为可选项;
console.log('-----------------')
//实现push()
var f1 = [1,2]
f1.splice(f1.length,0,3,4) 
console.log(f1) //[1,2,3,4]
//实现pop()
var f1 = [1,2]
f1.splice(-1,1)
console.log(f1) //[1]
//实现shift()
var f1 = [1,2]
f1.splice(0,1)
console.log(f1) //[2]
//实现unshift()
var f1 = [1,2]
f1.splice(0,0,3)
console.log(f1) //[3,1,2]

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

function squareArr(arr){
    for(var i=0;i<arr.length;i++){
        arr[i]*=arr[i]
    }
}
var arr = [2, 4, 6]
squareArr(arr)
console.log(arr) // [4, 16, 36]

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

function filterPositive(arr){
    var newArr=[]
    for(var i=0;i<arr.length;i++){
        if((/^\d*$/).test(arr[i])){
            newArr.push(arr[i])
        }
    }
    return newArr
}
var arr = [3, -1,  2,  '饥人谷', true]
var newArr = filterPositive(arr)
console.log(newArr) //[3, 2]
console.log(arr) //[3, -1,  2,  '饥人谷', true]

三、Date

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

var str = getChIntv("2017-05-30");
console.log(str);  // "现在离2017-05-30已经过了0天7小时51分17秒"
var str1 = getChIntv("2017-05-31");
console.log(str1); //"现在就是2017-05-31"
var str2 = getChIntv("2017-06-01");
console.log(str2); //"距2017-06-01还有0天16小时8分34秒"

function getChIntv(str){
    if(/^\d{4}-[01]\d{1}-([012]\d{1}|3[01])$/.test(str)){
        var now = Date.now()
        var fixedDate = Date.parse(str)-8*60*60*1000
        var interval = fixedDate - now
        var day = parseInt(interval/(60*60*24*1000))
        var hour = parseInt(interval%(60*60*24*1000)/(60*60*1000))
        var min = parseInt(interval%(60*60*24*1000)%(60*60*1000)/(60*1000))
        var sec = parseInt(interval%(60*60*24*1000)%(60*60*1000)%(60*1000)/1000)
        if(interval>-86400000&&interval<0){
            return '现在就是'+str
        }else if(interval<-86400000){
            return '现在离'+str+'已经过了'+(-day-1)+'天'+(-hour)+'小时'+(-min)+'分'+(-sec)+'秒'
        }else{
            return '距'+str+'还有'+day+'天'+hour+'小时'+min+'分'+sec+'秒'
        }   
    }
}

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

var str = getChsDate('2015-01-08');
function getChsDate(str){
    var CN = ['零','一','二','三','四','五','六','七','八','九']
    var a = str.split('-')
    var y = a[0].split(''),m = a[1].split(''),d = a[2].split('')
    str = transY(y)+'年'+transMD(m)+'月'+transMD(d)+'日'
    return str

    function transY(arr){
        arr = trim(arr)
        for(var i=0;i<arr.length;i++){
            arr[i]=CN[arr[i]]
        }
        return arr.join('')
    }
    function transMD(brr){
        brr = trim(brr)
        if(brr.length===1){
            brr=CN[parseInt(brr)]
            return brr
        }else if(parseInt(brr[0])===1){
            brr[0]='十'
            brr[1]=CN[parseInt(brr[1])]
            return brr.join('')
        }else {
            for(var i=0;i<brr.length;i++){
              brr[i]=CN[brr[i]]
            }
            brr.splice(1,0,'十')  //splice返回的是被删除的元素,不是修改后的数组
            console.log(brr.join(''))
            return brr.join('')
        }
    }
    function trim(arr){
        if(parseInt(arr[0])===0){
            arr.shift()
        }
        return arr
    }
}
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 a = Date.now()
    var interval = (a-time)/1000
    if(interval/60<1){
        return '刚刚'
    }else if(interval/60<60){
        var b = parseInt(interval/60)
        return b+'分钟前'
    }else if(interval/(60*60)<24){
        var b = parseInt(interval/(60*60))
        return b+'小时前'
    }else if (interval/(60*60*24)<30){
        var b = parseInt(interval/(60*60*24))
        return b+'天前'
    } else if(interval/(60*60*24*30)<12){
        var b = parseInt(interval/(60*60*24*30))
        return b+'月前'
    } else {
        var b = parseInt(interval/(60*60*24*30*12))
        return b+'年前'
    }
}
var str = friendlyDate('1496049631767')  //1天前
var str2 = friendlyDate('1483941245793') //4月前
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,212评论 0 4
  • .写一个函数,返回从min到max之间的 随机整数,包括min不包括max function randomness...
    邢烽朔阅读 312评论 0 1
  • 1、写一个函数,返回从min到max之间的随机整数,包括min不包括max ···function rand(mi...
    暂时没有好名字阅读 168评论 0 0
  • When this correlation is positive the model is tantamount...
    董八七阅读 189评论 0 0
  • 感恩生命中遇见给我帮助,有励志的朋友,从她们身上看见朋友们的优秀,也很震撼我的心智,也有心想跟随她们的步伐让自己活...
    刘爱玲阅读 100评论 0 0