Math任务
1. 写一个函数,返回从min到max之间的随机整数,包括min不包括max
function random(min,max) {
return min + Math.floor(Math.random()*(max-min))
}
2.写一个函数,返回从min到max之间的随机整数,包括min和max
function random(min,max) {
return min + Math.floor(Math.random()*(max+1-min))
}
3. 写一个函数,生成一个长度为 n 的随机字符串,字符串字符的取值范围包括0到9,a到 z,A到Z
function random(min,max) {
return min + Math.floor(Math.random()*(max-min))
}
function randomStr(len) {
var dict = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
var str = ''
for (var i = 0; i < len; i++) {
str +=dict[random(0,62)]
}
return str
}
4. 写一个函数,生成一个随机 IP 地址,一个合法的 IP 地址为 0.0.0.0~255.255.255.255
function random(min,max) {
return min + Math.floor(Math.random()*(max-min))
}
function randomIP(len) {
var arr=[]
for (var i = 0; i < 4; i++) {
arr.push(random(0,256))
}
return arr.join('.')
}
5. 写一个函数,生成一个随机颜色字符串,合法的颜色为#000000~ #ffffff
function random(min,max) {
return min + Math.floor(Math.random()*(max-min))
}
function randomColor() {
var dict = '0123456789abcdef'
var color = '#'
for (var i = 0; i < 6; i++) {
color += dict[random(0,16)]
}
renturn color
}
数组任务
1. 数组方法里push、pop、shift、unshift、join、splice分别是什么作用?用 sp4lice函数分别实现push、pop、shift、unshift方法
- push():接受一个或多个参数,表示将一个或多个项添加至数组的尾部,返回值是添加后数组的长度
- pop():将数组尾部的项删除,返回值是被删除的项
- shift():将数组头部的项删除,返回值是被删除的项
- unshift():接受一个或多个参数,表示将一个或多个项添加至数组的头部,返回值是添加后数组的长度
- join():接受一个字符串参数,表示将数组的每一项通过传入的参数连接成一个字符串并返回
- splice(var1,var2,[var3[,var4...]]):var1表示要删除的项的位置,var2表示从指定位置开始要删除的项的个数,var3,var4...表示在指定位置插入的项
var arr=[1,2,3,4,5];
push: arr.splice(arr.length,0,6) // 末尾添加6
pop: arr.splice(arr.length-1,1);
shift: arr.splice(0,1);
unshift: arr.splice(0,0,0); //头部插入 0
2. 写一个函数,操作数组,数组中的每一项变为原来的平方,在原数组上操作
function squareArr(arr) {
for (var i = 0; i < arr.length; i++) {
arr[i] = arr[i] * arr[i]
}
retun arr
}
3. 写一个函数,操作数组,返回一个新数组,新数组中只包含正数,原数组不变
function positivenumber(arr) {
var newarr = []
for (var i = 0; i < arr.length; i++) {
if (typeof arr[i] === 'number' && arr[i] > 0) {
newarr.push(arr[i])
}
}
return newarr
}
Date任务
1. 写一个函数getChIntv,获取从当前时间到指定日期的间隔时间
function getChIntv(dateStr) {
var targetDate = new Date(dateStr)
var curDate = new Date()
var offset = Math.abs(targetDate - curDate)
var totlaSeconds = Math.floor(offset/1000)
var second = totlaSeconds%60
var totalMinutes = math.floor((offset/1000)/60)
var minutes = totalMinutes%60
var totalHours = Math.floor(totalMinutes/60)
var hours = totalHours%24
var totalDays = Math.floor(totalHours/24)
return totalDays + '天' + hours + '小时' + minutes + '分钟' + second +'秒'
}
2. 把hh-mm-dd格式数字日期改成中文日期
function getChsDate(dateStr) {
var arr =['零', '一', '二', '三', '四', '五', '六', '七', '八', '九', '十',
'十一', '十二', '十三', '十四', '十五', '十六', '十七', '十八', '十九', '二十',
'二十一', '二十二', '二十三', '二十四', '零二十五', '二十六', '二十七', '二十八', '二十九', '三十',
'三十一']
var newarr = dateStr.split('-')
var year = newarr[0]
var month = newarr[1]
var day = newarr[2]
var yearstr = '';
for (var i = 0; i < year.length; i++) {
yearstr += arr[year[i]]
}
var monthstr = arr[parseInt(month)]
var daystr = arr[parseInt(day)]
return (yearstr + '年' + monthstr + '月' + daystr + '日')
}
3. 写一个函数,参数为时间对象毫秒数的字符串格式,返回值为字符串。假设参数为时间对象毫秒数t,根据t的时间分别返回如下字符串
function friendlyDate(time) {
var timeStart = time;
var timeEnd = new Date().getTime()
var offsetTime = timeEnd - timeStart
var minutes = 1000*60
var hours=1000*60*60
var days=1000*60*60*24
var month=1000*60*60*24*30
var year=1000*60*60*24*30*12
if(offsetTime<minutes&&offsetTime>=0){
return '刚刚'
}else if(offsetTime<hours&&offsetTime>=minutes){
return parseInt(offsetTime/minutes)+'分钟前'
}else if(offsetTime>=hours&&offsetTime<days){
return parseInt(offsetTime/hours)+'小时前'
}else if(offsetTime>=days&&offsetTime<month){
return parseInt(offsetTime/days)+'天前'
} else if(offsetTime>=month&&offsetTime<year){
return parseInt(offsetTime/month)+'个月前'
} else {
return parseInt(offsetTime/year)+'年前'
}
}