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的时间分别返回如下字符串:
- 刚刚( 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 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)