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)+'年前'
}
}