Math、数组、Date

Math 方法


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

function getRandom(min, max){
    if(min > max){
        let tmp = min
        min = max
        max = tmp
    }

    return min + Math.floor(Math.random() * (max - min))
}

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

function getRandom(min, max){
    if(min > max){
        let tmp = min
        min = max
        max = tmp
    }

    return min + Math.floor(Math.random() * (max - min + 1))
}

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

function getRandomStr(n){
    const allChar = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLNOPQRSTUVWXYZ'
    let str = ''
    for(let i = 0; i < n; i++){
        str += allChar[Math.floor(Math.random() * (62))]
    }
    return str
}

var a = getRandomStr(10)
console.log(a)

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

function getRandomIp(){
    let ipArr = []
    for(let i = 0; i < 4; i++){
        ipArr.push(Math.floor(Math.random() * 256))
    }
    return ipArr.join('.')
}

var ip = getRandomIp()
console.log(ip)

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

function getRandomColor(){
    const baseNum = [
        '0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'
    ]

    let color = '#'
    for(let i = 0; i < 6; i++){
        color += baseNum[Math.floor(Math.random() * 16)]
    }
    return color
}

var color = getRandomColor()
console.log(color)

数组方法


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

函数 作用
push 往数组末尾添加一个元素
pop 把数组最后一位弹出来
shift 把数组的第一位弹出来
unshift 往数组的首部添加一个元素
join 把数组的每一位用指定字符连接起来
splice 向/从数组中添加/删除项目,然后返回被删除的项目,改变原数组

splie 实现 push

let a = [1,2,3]
a.splice(a.length, 0 ,222)
console.log(a)

splice 实现 pop

let a = [1,2,3]
a.splice(-1, 1)
console.log(a)

splice 实现 shift

let a = [1, 2, 3]
a.splice(0, 1)
console.log(a)

splice 实现 unshift

let a = [1, 2, 3]
a.splice(0, 0, 222)
console.log(a)

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

function squareArray(arr){
    const length = arr.length
    const pow = 2
    for(let n = 0; n < length; n++){
        arr.splice(n, 1, Math.pow(arr[n], pow))
    }
    return arr
}

let arr = squareArray([1,2,3])
console.log(arr)

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

function filterPositive(arr){
    return arr.filter((element, index, arr) => {
        return typeof element === 'number' && element > 0
    })
}
var arr = [3, -1,  2,  '饥人谷', true]
var newArr = filterPositive(arr)
console.log(newArr) //[3, 2]
console.log(arr) //[3, -1,  2,  '饥人谷', true]

Data 任务

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

function getChIntv(dateStr){
    let targetDate = new Date(dateStr)
    let current = new Date()
    let timeDiff = Math.abs(targetDate - current)

    let totalSeconds = Math.floor(timeDiff / 1000)
    let seconds = Math.floor(totalSeconds % 60)

    let totalMinutes = Math.floor(totalSeconds / 60)
    let minutes = Math.floor(totalMinutes % 60)

    let totalHours = Math.floor(totalMinutes / 60)
    let hours = Math.floor(totalHours % 24)

    let days = Math.floor(totalHours / 24)
    
    let result = '距离 ' + dateStr + ' 还剩下 ' + days + ' 天 ' + hours + ' 小时 ' + seconds + ' 秒 ' 
    return result
}

var date = getChIntv('2017-10-13')
console.log(date)

二、把 hh-mm-dd 格式数字日期改成中文日期

function getChsDate(dateStr){
    const cnNum = [
        '零','一','二','三','四','五','六','七','八','九',
        '十','十一','十二','十三','十四','十五','十六','十七','十八','十九',
        '二十','二十一','二十二','二十三','二十四','二十五','二十六','二十七','二十八','二十九',
        '三十','三十一'
    ]
    let dateArr = dateStr.split('-')

    let year = ''
    for(let i = 0; i < dateArr[0].length; i++){
        year += cnNum[Number(dateArr[0][i])]
    }

    let month = cnNum[Number(dateArr[1])]

    let day = cnNum[Number(dateArr[2])]

    let result = year + ' 年 ' + month + ' 月 ' + day + ' 日 ' 
    return result
}

var date = getChsDate('2017-10-01')
console.log(date)

三、写一个函数,参数为时间对象毫秒数的字符串格式,返回值为字符串。假设参数为时间对象毫秒数 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){
    let currentTime = Date.now()
    let timeDiff = Math.floor((currentTime - time) / 1000)
    const dateFormat = {
        '刚刚': 60,
        '3分钟前': 3600,
        '8小时前': 3600 * 24,
        '3天前': 3600 * 24 * 30,
        '2个月前': 3600 * 24 * 30 * 12,
        '8年前': 3600 * 24 * 30 * 12
    }

    for(let key in dateFormat){
        if(timeDiff < dateFormat[key]){
            return key
        }
    }
    return '8年前'
}

var fdate = friendlyDate(1480000000000)
console.log(fdate)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,045评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,114评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,120评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,902评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,828评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,132评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,590评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,258评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,408评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,335评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,385评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,068评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,660评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,747评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,967评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,406评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,970评论 2 341

推荐阅读更多精彩内容

  • .写一个函数,返回从min到max之间的 随机整数,包括min不包括max function randomness...
    邢烽朔阅读 307评论 0 1
  • Math 1、写一个函数,返回从min到max之间的随机整数,包括min不包括max 2、写一个函数,返回从min...
    阿鲁提尔阅读 343评论 0 1
  • 写一个函数,返回从min到max之间的 随机整数,包括min不包括max 写一个函数,返回从min都max之间的 ...
    LeeoZz阅读 301评论 0 0
  • Math 1.写一个函数,返回从min到max之间的 随机整数,包括min不包括max 2.写一个函数,返回从mi...
    饥人谷_bigJiao阅读 545评论 0 0
  • Math 写一个函数,返回从min到max之间的 随机整数,包括min不包括max 写一个函数,返回从min都ma...
    ezrealor阅读 252评论 0 1