一.Math
1、寫一個函數,返回從min到max之間的 隨機整數,包括min不包括max
//不包含最大數 function getNum(min,max){ //包含最小值,隨機最小值與最大值之間的整數且不包含最大值 console.log(min+Math.floor(Math.random()*(max-min))) } getNum(10,15)
2、寫一個函數,返回從min都max之間的 隨機整數,包括min包括max
//也包含最大數
function getNum2(min,max){ //包含最小值,隨機最小值與最大值之間的整數且包含最大值 console.log(min+Math.floor(Math.random()*(max+1-min))) } getNum2(10,15)
3、寫一個函數,生成一個長度為 n 的隨機字符串,字符串字符的取值范圍包括0到9,a到 z,A到Z。
function getRandStr(len){ //補全函數 var str1='' var str = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'; for(var i=0;i<len;i++){ var ss=parseInt(Math.random()*str.length); str1 += str[ss]; } return str1 } var str = getRandStr(10); // 例:0a3iJiRZap console.log(str);
4、寫一個函數,生成一個隨機 IP 地址,一個合法的 IP 地址為 0.0.0.0~255.255.255.255
function getRandIP(){ //補全 var ip='' for (var i=0; i<4; i++){ var str=Math.floor(Math.random()*256); ip += str; // 3個點是4個數 if( i<3 ){ ip += "."; } } return ip; }var ip = getRandIP()console.log(ip) // 例:10.234.121.45
5、寫一個函數,生成一個隨機顏色字符串,合法的顏色為#000000~ #ffffff
function getRandColor(){ var str = "0123456789abcdef"; var strlen = str.length; var colorstr = "#"; for(var i = 0; i < 6; i++){ var index = Math.floor(Math.random()*strlen); colorstr += str[strlen]; } return colorstr } var color = getRandColor() console.log(color) // 例:#3e2f1b
二.數組
1、數組方法里push、pop、shift、unshift、join、splice分別是什么作用?用 splice函數分別實現push、pop、shift、unshift方法
push()、pop()和unshift()、shift()這兩組同為對數組的操作,并且會改變數組的本身的長度及內容。
不同的是 push()、pop() 是從數組的尾部進行增刪,unshift()、shift() 是從數組的頭部進行增刪。
splice() 方法向/從數組中添加/刪除項目,然后返回被刪除的項目。該方法會改變原始數組。
join() 方法用于把數組中的所有元素放入一個字符串。元素是通過指定的分隔符進行分隔的。
//splice函數分別實現push、pop、shift、unshift方法//例子: var arr = [1,2,3,4,5] //push arr.splice(arr.length,0,6); //位置,要刪除元素的個數,要添加到數組的元素 console.log(arr);//[1,2,3,4,5,6] console.log(arr.length) //pop arr.splice(arr.length-1,1) console.log(arr);//[1,2,3,4,5] //shift arr.splice(0,1); console.log(arr);//[2,3,4,5] //unshift arr.splice(0,0,1); console.log(arr);//[1,2,3,4,5]
2、寫一個函數,操作數組,數組中的每一項變為原來的平方,在原數組上操作
function squareArr(arr){ for(var i = 0; i < arr.length; i++ ){ arr[i] *= arr[i] } return arr; } var arr = [2, 4, 6] squareArr(arr) console.log(arr) // [4, 16, 36]
3、寫一個函數,操作數組,返回一個新數組,新數組中只包含正數,原數組不變
function filterPositive(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; } var arr = [3, -1, 2, '饑人谷', true] var newArr = filterPositive(arr) console.log(newArr) //[3, 2]
三.Date
1、 寫一個函數getChIntv,獲取從當前時間到指定日期的間隔時間
function getChIntv(s) { //時間=指定時間-當前時間 var time = Math.abs(Date.parse(s) - Date.now()); //天數=時間/天的毫秒 var days = parseInt(time/(1000*60*60*24)); //幾小時=時間%天的毫秒/一小時毫秒 var hours = parseInt((time%(1000*60*60*24))/(1000*60*60)); //幾分鐘=時間%天的毫秒/一小時毫秒/一分鐘毫秒 var minutes = parseInt(((time%(1000*60*60*24))%(1000*60*60))/(1000*60)); //幾秒=時間%天的毫秒/一小時毫秒/一分鐘毫秒/一秒毫秒 var seconds = parseInt(((time%(1000*60*60*24))%(1000*60*60))%(1000*60)/1000); return days + '天' + hours + '小時' + minutes + '分鐘' + seconds+ '秒' } var str = getChIntv('2017-7-01'); console.log(str);
2、把hh-mm-dd格式數字日期改成中文日期
function getChsDate(s) { var arr = ['零','一','二','三','四','五','六','七','八','九','十','十一','十二','十三' , '十四','十五','十六','十七','十八','十九','二十','二十一','二十二','二十三','二十四', '二十五','二十六','二十七','二十八','二十九','三十','三十一'] //字符串拆成數組 var time = s.split('-'); //
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 msec=new Date() // getTime()返回距 1970 年 1 月 1 日之間的毫秒數 var nowTime=msec.getTime() var sec=(nowTime-time)/1000 if(sec<60){ return '剛剛' }else if(sec>=60&&sec<3600){ return '三分鐘前' }else if(sec>=3600&&sec<8*3600){ return '8小時前' }else if(sec>=24*3600&&sec<24*3600*30){ return '3天前' }else if(sec>=24*3600*30&&sec<24*3600*30*12){ return '2個月前' }else if(sec>=24*3600*30*12){ return '8年前' } } var str = friendlyDate( '1484286699422' ) var str2 = friendlyDate('1483941245793') console.log(str) //2個月前 console.log(str2) //2個月前
本篇對js基礎相關知識進行的相關的講解,更多知識請關注Gxl網。
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com