1、寫(xiě)一個(gè)函數(shù),返回從min到max之間的 隨機(jī)整數(shù),包括min不包括max
function random(min, max) {
return min + Math.floor(Math.random()*(max-min))
}
var arr = [];
for(var i=0; i<10; i++){
arr.push(random(min,max))
}
console.log(arr)
2、寫(xiě)一個(gè)函數(shù),返回從min都max之間的 隨機(jī)整數(shù),包括min包括max
function random(min, max) {
return min + Math.floor(Math.random()*(max-min))
}
var arr = [];
for(var i=0; i<10; i++){
arr.push(random(min,max+1))
}
console.log(arr)
3、寫(xiě)一個(gè)函數(shù),生成一個(gè)長(zhǎng)度為 n 的隨機(jī)字符串,字符串字符的取值范圍包括0到9,a到 z,A到Z。
function getRanStr(len) {
var dict = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHEIJKLMNOQPRSTUVWXYZ"
var str = ""
for(var i = 0; i < len; i++){
str += dict[Math.floor(Math.random()*62)]
}
return str
}
console.log(getRanStr(10))
4、寫(xiě)一個(gè)函數(shù),生成一個(gè)隨機(jī) IP 地址,一個(gè)合法的 IP 地址為 0.0.0.0~255.255.255.255
function getRandIP(){
var arr = []
for(var i = 0; i < 4; i++){
arr[i] = Math.floor(Math.random()*256)
var ip = arr.join('.')
}
return ip
}
console.log(getRandIP())
5、寫(xiě)一個(gè)函數(shù),生成一個(gè)隨機(jī)顏色字符串,合法的顏色為#000000~ #ffffff
function getRandColor() {
var dict = '0123456789abcdef'
var str = ''
for(var i = 0; i < 6; i++){
str += dict[random(0,16)]
}
str = '#'+str
return str
}
console.log(getRandColor())
數(shù)組任務(wù)
1、數(shù)組方法里push、pop、shift、unshift、join、splice分別是什么作用?用 splice函數(shù)分別實(shí)現(xiàn)push、pop、shift、unshift方法
- push: 棧方法,在數(shù)組最后添加值,返回?cái)?shù)組長(zhǎng)度;
- pop: 棧方法,取出數(shù)組最后一個(gè)值,返回被刪除的元素;
- shit: 隊(duì)列方法,刪除數(shù)組最前面的值,返回被刪除的元素;
- unshift: 隊(duì)列方法,在數(shù)組最前面添加一個(gè)或多個(gè)值,返回?cái)?shù)組長(zhǎng)度;
- join:以指定分隔符將數(shù)組的值鏈接成字符串,返回生成的新字符串,()內(nèi)接受指定分隔符參數(shù),若為空字符,則元素直接聯(lián)結(jié)成字符串;
- JavaScript提供了一個(gè)splice方法用于一次性解決數(shù)組添加、刪除(這兩種方法一結(jié)合就可以達(dá)到替換效果),方法有三個(gè)參數(shù):1.開(kāi)始索引;2.刪除元素的位移;3.插入的新元素,當(dāng)然也可以寫(xiě)多個(gè)。splice方法返回一個(gè)由刪除元素組成的新數(shù)組,沒(méi)有刪除則返回空數(shù)組。
- 用 splice函數(shù)分別實(shí)現(xiàn)push、pop、shift、unshift方法:
1.push:
var arr = [1,2,3,6,7,9]
function spliceToPush(arr, elements) {
arr.splice(arr.length, 0, elements)
return arr
}
console.log(spliceToPush(arr, 'asd')) // [1, 2, 3, 6, 7, 9, "asd"]
2.pop:
var arr = [1, 2, 3]
function spliceToPop(arr) {
arr.splice(arr.length - 1,1)
return arr
}
console.log(spliceToPop(arr)) // [1, 2]
3.shit:
var arr = [1,2,3,4,5,6,7]
function spliceToShift(arr) {
arr.splice(0,1)
return arr
}
console.log(spliceToShift(arr)) // [2, 3, 4, 5, 6, 7]
4.unshit:
var arr = [1,2,3,4,5,6,7]
function spliceToUnshift(arr, elements) {
arr.splice(0, 0, elements)
return arr
}
console.log(spliceToUnshift(arr, 'asddsa')) // ["asddsa", 1, 2, 3, 4, 5, 6, 7]
2、寫(xiě)一個(gè)函數(shù),操作數(shù)組,數(shù)組中的每一項(xiàng)變?yōu)樵瓉?lái)的平方,在原數(shù)組上操作
var arr = [2, 4, 6]
function squareArr(arr){
var arr = []
for(var i= 0; i < arr.length; i++){
arr[i] = arr[i] * arr[i]
}
return arr
}
console.log(squareArr(arr)) // [4, 16, 36]
3、寫(xiě)一個(gè)函數(shù),操作數(shù)組,返回一個(gè)新數(shù)組,新數(shù)組中只包含正數(shù),原數(shù)組不變
var arr = [3, -1, 2, '饑人谷', true]
function filterPositive(arr){
var newArr = []
for(var i = 0; i < arr.length; i++ ){
if (typeof arr[i] === 'number') {
if (arr[i] > 0) [
newArr.push(arr[i])
]
}
}
return newArr
}
var newArr = filterPositive(arr)
console.log(newArr)//[3,2]
console.log(arr)//[3, -1, 2, '饑人谷', true]
Date 任務(wù)
1、 寫(xiě)一個(gè)函數(shù)getChIntv,獲取從當(dāng)前時(shí)間到指定日期的間隔時(shí)間
function getChIntv(str){
var timeEnd = Date.parse(str);
var timeStart = new Date().getTime();
var offset = timeEnd - timeStart;
var days = parseInt(offset/(24*60*60*1000));
var hours = parseInt(offset%(24*60*60*1000)/(60*60*1000));
var minutes = parseInt(offset%(24*60*60*1000)%(60*60*1000)/(60*1000))
var seconds = parseInt(offset%(24*60*60*1000)%(60*60*1000)%(60*1000)/1000)
console.log(seconds);
var str ='距離'+str+'還有'+days+'天'+
hours +'小時(shí)' + minutes +'分'+ seconds +'秒';
return str;
}
var str = getChIntv("2017-02-08");
console.log(str);
2、把hh-mm-dd格式數(shù)字日期改成中文日期
function getChsDate(date1){
var chs ={"0":"零","1":"一","2":"二","3":"三","4":"四","5":"五","6":"六","7":"七","8":"八","9":"九","10":"十","11":"十一","12":"十二","13":"十三","14":"十四","15":"十五","16":"十六","17":"十七","18":"十八","19":"十九","20":"二十","21":"二十一","22":"二十二","23":"二十三","24":"二十四","25":"二十五","26":"二十一六","27":"二十七","28":"二十八","29":"二十九","30":"三十","31":"三十一"};
var str="";
var date2 =new Date(date1);
var year= date2.getFullYear().toString();
str+=chs[year[0]];
str+=chs[year[1]];
str+=chs[year[2]];
str+=chs[year[3]];
str +="年";
str +=chs[date2.getMonth()+1];
str +="月";
str +=chs[date2.getDate()];
str +="日";
return str;
}
var str = getChsDate('2015-01-08');
console.log(str); // 二零一五年一月八日
3、寫(xiě)一個(gè)函數(shù),參數(shù)為時(shí)間對(duì)象毫秒數(shù)的字符串格式,返回值為字符串。假設(shè)參數(shù)為時(shí)間對(duì)象毫秒數(shù)t,根據(jù)t的時(shí)間分別返回如下字符串:
剛剛( t 距當(dāng)前時(shí)間不到1分鐘時(shí)間間隔)
3分鐘前 (t距當(dāng)前時(shí)間大于等于1分鐘,小于1小時(shí))
8小時(shí)前 (t 距離當(dāng)前時(shí)間大于等于1小時(shí),小于24小時(shí))
3天前 (t 距離當(dāng)前時(shí)間大于等于24小時(shí),小于30天)
2個(gè)月前 (t 距離當(dāng)前時(shí)間大于等于30天小于12個(gè)月)
8年前 (t 距離當(dāng)前時(shí)間大于等于12個(gè)月)
function friendlyDate(time){
var date=Date.now()-new Date(parseInt(time));
var str;
if(date<0){
str = "那是未來(lái)";
}else if(date<60*1000){
str = "剛剛";
}else if(date<(3600*1000)){
str =Math.floor(date/60/1000)+"分鐘前";
}else if(date<(24*3600*1000)){
str =Math.floor(date/3600/1000)+"小時(shí)前";
}else if(date<(30.41*24*3600*1000)){
str =Math.floor(date/24/3600/1000) + "天前";
}else if(date<(365.24*24*3600*1000)){
str =Math.floor(date/30.41/24/3600/1000) + "月前";
}else if(date<(10000*365.24*24*3600*1000)){
str =Math.floor(date/365.24/24/3600/1000) + "年前";
}
return str;
}
var str = friendlyDate( '1484286699422' ) //1分鐘前
console.log(str);
var str2 = friendlyDate('1483941245793') //4天前
console.log(str2);