Math任務(wù)
1.寫一個函數(shù),返回從min到max之間的隨機整數(shù),包括min不包括max
function getRandom(min, max) {
return Math.floor(Math.random() * (max-min)) + min;
}
2.寫一個函數(shù),返回從min都max之間的隨機整數(shù),包括min包括max
function getRandom(min, max) {
return Math.floor(Math.random() * (max-min+1)) + min;
}
3.寫一個函數(shù),生成一個長度為 n 的隨機字符串,字符串字符的取值范圍包括0到9,a到 z,A到Z。
function getRandStr(len){
var ALPHABET = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
ALPHABET += 'abcdefghijklmnopqrstuvwxyz';
ALPHABET += '0123456789';
var str = '';
for (var i = 0; i < len; i++) {
var rand = Math.floor(Math.random() * ALPHABET.length);
str += ALPHABET[rand];
}
return str;
}
var str = getRandStr(10);
4.寫一個函數(shù),生成一個隨機 IP 地址,一個合法的 IP 地址為0.0.0.0~255.255.255.255
function getRandIP() {
var arr = [];
for (var i = 0; i < 4; i++) {
arr[i] = getRandom(0,255);
}
return arr.join('.');
}
function getRandom(min, max) {
return Math.floor(Math.random() * (max-min+1)) + min;
}
var ip = getRandIP()
console.log(ip)
5.寫一個函數(shù),生成一個隨機顏色字符串,合法的顏色為#000000~ #ffffff
function getRandColor(){
var arr = [];
for (var i = 0; i < 6; i++) {
arr[i] = (getRandom(0,15)).toString(16);
}
return '#' + arr.join('');
}
function getRandom(min, max) {
return Math.floor(Math.random() * (max-min+1)) + min;
}
var color = getRandColor()
console.log(color)
數(shù)組任務(wù)
1.數(shù)組方法里push、pop、shift、unshift、join、split分別是什么作用?用 splice函數(shù)分別實現(xiàn)push、pop、shift、unshift方法
- push在數(shù)組的末端添加一個或多個元素,并返回添加新元素后的數(shù)組長度。
- pop方法用于刪除數(shù)組的最后一個元素,并返回該元素。
- shift方法用于刪除數(shù)組的第一個元素,并返回該元素。
- unshift方法用于在數(shù)組的第一個位置添加元素,并返回添加新元素后的數(shù)組長度。
- join方法以參數(shù)作為分隔符,將所有數(shù)組成員組成一個字符串返回。
- split方法按照給定規(guī)則分割字符串,返回一個由分割出來的子字符串組成的數(shù)組。
arr.push(num) === arr.splice(arr.length, 0, num);
arr.pop() === arr.splice(arr.length-1, 1);
arr.shift() === arr.splice(0, 1);
arr.unshift(num) === arr.splice(0, 0, num);
2.寫一個函數(shù),操作數(shù)組,數(shù)組中的每一項變?yōu)樵瓉淼钠椒?,在原?shù)組上操作
function squareArr(arr){
for (var i = 0; i < arr.length; i++) {
arr[i] = arr[i]*arr[i];
}
}
var arr = [2, 4, 6]
squareArr(arr)
console.log(arr)
3.寫一個函數(shù),操作數(shù)組,返回一個新數(shù)組,新數(shù)組中只包含正數(shù),原數(shù)組不變
function filterPositive(arr){
return arr.filter(function(n) {
return typeof n === 'number' && n > 0;
})
}
var arr = [3, -1, 2, '饑人谷', true]
var newArr = filterPositive(arr)
console.log(arr) //[3, 2]
console.log(newArr)
Date 任務(wù)
1. 寫一個函數(shù)getChIntv,獲取從當(dāng)前時間到指定日期的間隔時間
function getChIntv(str) {
var newStr = str.split('-').join('/')
var curr = new Date()
var then = new Date(newStr)
var differ = (curr - then)/1000;
if (differ > 0) {
var tense = '已經(jīng)過去'
}else {
tense = '還有'
differ = - differ
}
var days = parseInt(differ/(3600*24))
var hours = parseInt(differ/3600%24)
var mins = parseInt(differ/60%60)
var second = parseInt(differ%60)
return '距'+str+tense+days+'天'+hours+'小時'+mins+'分'+second+'秒'
}
var str = getChIntv("2017-03-13");
console.log(str);
2.把hh-mm-dd格式數(shù)字日期改成中文日期
function getChsDate(str) {
var dict = ["零","一","二","三","四","五","六","七","八","九","十", "十一", "十二", "十三", "十四", "十五", "十六", "十七", "十八", "十九", "二十", "二十一", "二十二", "二十三", "二十四", "二十五", "二十六", "二十七", "二十八", "二十九", "三十", "三十一"];
var arr = str.split('-')
var yearNum = arr[0].split('');
var yearStr = '';
for (var i = 0; i < yearNum.length; i++) {
yearStr += dict[yearNum[i]];
}
console.log(yearStr)
var monthNum = arr[1].split('');
var monthStr = '';
for (var i = 0; i < monthNum.length; i++) {
if (i == 0 && monthNum[0] == '0') { continue; }
monthStr += dict[monthNum[i]];
}
console.log(monthStr)
var dayNum = arr[2].split('');
var dayStr = '';
for (var i = 0; i < dayNum.length; i++) {
if (i == 0 && dayNum[0] == '0') { continue; }
dayStr += dict[dayNum[i]];
}
console.log(dayStr)
return yearStr+'年'+monthStr+'月'+dayStr+'日';
}
var str = getChsDate('2015-01-08');
console.log(str);
3.寫一個函數(shù),參數(shù)為時間對象毫秒數(shù)的字符串格式,返回值為字符串。假設(shè)參數(shù)為時間對象毫秒數(shù)t,根據(jù)t的時間分別返回如下字符串:
function friendlyDate(time){
var curr = Date.now()
var differ = (curr - time)/1000
var show = ''
var days = differ/3600/24
if (days >= 1) {
if (days < 30) {
show = '3天前'
}else if (days>30 && days/30<12) {
show = '2個月前'
}else {
show = '8年前'
}
}else {
var mins = differ/60;
if (mins >= 60) {
show = '8小時前'
}else if (mins >= 1) {
show = '3分鐘前'
}else {
show = '剛剛'
}
}
return show
}
var str = friendlyDate( '1489393613872' ) // 剛剛
console.log(str)