Math数组Date

2017-07-31  本文已影响0人  谨言_慎行

Math任务

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

function random(a,b) {
    return a + Math.floor(Math.random()*(b-a))
}

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

function random(a,b+1) {
    return a + Math.floor(Math.random()*(b-a))
}

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

function random(a,b) {
    return a + Math.floor(Math.random()*(b-a))
}
function randomStr(n){
    var dict = "0123456789qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM"
    var str = ''
    for(i = 0;i < n;i++){
        str += dict[random(0,62)]
    }
    return str
}
randomStr(5)

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

function random(a,b){
    return a + Math.floor(Math.random()*(b-a))
}
function randomIP(len){
var arr = []
for(i=0;i<4;i++){
    arr.push(random(0,256))
}
    return arr.join('.')
}
 randomIP()

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

function random(a,b){
    return a + Math.floor(Math.random()*(b-a))
}
var dict = "0123456789abcdef"
function randomC(len){
var str = ''
for(i=0;i<6;i++){
    str += dict[random(0,16)]
}
    return '#'+ str
}
randomC()

数组

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

/*push方法的实现与pop方法的实现(栈方法)*/
var arr = [3,5,6]
arr.push(8)// 在数组末尾加上8,会输出数组的长度
arr.pop()// 拿出数组末尾数,输出数组末尾值

/*shift方法的实现和unshift的实现方法*/
var arr = [5,8,6]
arr.shift()// 拿掉数组开始的数字,输出未拿掉数字前的数组长度
arr.unshift(8)// 在其实位置加上数字,输出添加后的数组长度

/*splice方法用于一次性解决数组添加、删除(这两种方法一结合就可以达到替换效果),方法有三个参数
1.开始索引
2.删除元素的位移 
3.插入的新元素,当然也可以写多个(在索引位置前)
splice方法返回一个由删除元素组成的新数组,没有删除则返回空数组*/
var arr = [4,8,6]
arr.splice(1,0, 25, 56)
console.log(arr)//[4,25,56,8,6]
/*join('')将数组链接成字符串*/
var arr = [5,4,6]
arr.join('-')//"5-4-6"

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

var arr = [5,6,8]
arr.splice(3,0, 9)// 用splice实现push 起始位置为arr.length
var arr = [5,6,8]
arr.splice(2,1)//实现pop  起始位置为arr.length-1,删除元素位移为1
var arr = [5,6,8]
arr.splice(0,1)//实现shift  起始位置为0,删除元素位移为1
var arr = [5,6,8]
arr.splice(0,0, 4)//实现unshift  起始位置为0,删除元素位移为0,添加内容

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

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

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

function filterPositive(arr) {
    var newArr = []
    var j = 0
    for(var i = 0;i < arr.length;i++) {
        if(typeof arr[i] === "number" && arr[i] > 0){
            newArr[j] = arr[i]
            j++
        }
    }return newArr
}
var arr = [3, -1,  2,  '饥人谷', true]
var newArr = filterPositive(arr)
console.log(newArr) 
console.log(arr)

Date 任务

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

function getCHIntv(dateStr){        
    var targetDate = new Date(dateStr)
    var curDate = new Date()
    var offset = Math.abs(targetDate - curDate)

    var totalSeconds = Math.floor(offset/1000)
    var senond = totalSeconds%60
    var totalMins = Math.floor(totalSeconds/60)
    var min = totalMins%60
    var totalHours = Math.floor(totalMins/60)
    var hour = totalHours%24
    var day = Math.floor(totalHours/24)

    return day + '天' + hour + '小时' + min + '分钟' + senond + '秒'
}
   getCHIntv('2017-8-23')

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

function getChsDate(date){
    var dict = ['零','一','二','三','四','五','六','七','八','九','十','十一','十二','十三','十四','十五','十六','十七','十八','十九','二十','二十一','二十二','二十三','二十四','二十五','二十六','二十七','二十八','二十九','三十','三十一']
    var arr = []
    var newArr = date.split('-')
    var year = newArr[0]
    for(var i = 0; i < year.length; i++){
        arr.push(dict[year[i]])
    }
    arr.push("年")
    arr.push(dict[parseInt(newArr[1],10)])
    arr.push("月")
    arr.push(dict[parseInt(newArr[2],10)])
    arr.push("日")
    var newArr = arr.join('')
    return newArr
}
var str = getChsDate('2015-01-08');
console.log(str);

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

function friendlyDate(time){
    var friendlyDate = time
    var curDate = new Date().getTime()
    var offset = curDate - friendlyDate
    if(offset < 60000){
        return '刚刚'
    }else if(offset < 3600000){
        return '3分钟前'
    }else if(offset < 3600000*24){
        return '8小时前'
    }else if(offset < 3600000*24*30){
        return '3天前'
    }else if(offset < 3600000*24*30*12){
        return '2个月前'
    }else if(offset >= 3600000*24*30*12){
        return '8年前'
    }
}
    var str = friendlyDate( '1485584391984' ) 
    console.log(str)
    var str2 = friendlyDate('1405504991984') 
    console.log(str2)
上一篇下一篇

猜你喜欢

热点阅读