進(jìn)階6 Math·數(shù)組·Date

Math

1. 寫一個(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<20;i++){
    arr.push(random(1,5))
}
console.log(arr);
math-1測(cè)試.png
2. 寫一個(gè)函數(shù),返回從min都max之間的 隨機(jī)整數(shù),包括min包括max
function random(min,max){
    return min+Math.floor(Math.random() * (max - min+1));
}
var arr=[];
for(var i=0;i<20;i++){
    arr.push(random(1,5))
}
console.log(arr);
math-2測(cè)試.png
3. 寫一個(gè)函數(shù),生成一個(gè)長(zhǎng)度為 n 的隨機(jī)字符串,字符串字符的取值范圍包括0到9,a到 z,A到Z。
function getRandStr(len){
  //補(bǔ)全函數(shù)
    var dict = '0123456789abcdefghijklnmopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
    var randStr = ''
    for(var i=0;i<len;i++){
        randStr+=dict[random(0,62)] //Math.floor(Math.random()*dict.length)
    }
    return randStr;
}
var str = getRandStr(10); // 0a3iJiRZap
console.log(str);
math-3測(cè)試
4. 寫一個(gè)函數(shù),生成一個(gè)隨機(jī) IP 地址,一個(gè)合法的 IP 地址為 0.0.0.0~255.255.255.255
function getRandIP(){
  //補(bǔ)全
    var arr = [];
    for(var i=0;i<4;i++){
        arr.push(random(0,256));
    }
    return arr.join('.');
}
var ip = getRandIP()
console.log(ip) // 10.234.121.45
math-4測(cè)試.png
5. 寫一個(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)]//Math.floor(Math.random()*dict.length)
    }
    colorStr = '#'+str;
    return colorStr;
}
var color = getRandColor()
console.log(color)   // #3e2f1b
math-5測(cè)試.png

數(shù)組

1. 數(shù)組方法里push、pop、shift、unshift、join、splice分別是什么作用?用 splice函數(shù)分別實(shí)現(xiàn)push、pop、shift、unshift方法
方法 用法 作用
push Array.push(str) 在數(shù)組尾部添加一個(gè)或多個(gè)元素
pop Array.pop() 在數(shù)組尾部彈出一個(gè)或多個(gè)元素,并返回(對(duì)空數(shù)組則返回undefined
shift Array.shift() 將數(shù)組的第一個(gè)元素從原數(shù)組中刪除,并返回被刪除的元素的值(對(duì)空數(shù)組則返回undefined
unshift Array.unshift(str) 向數(shù)組的頭部添加一個(gè)或更多元素,并返回新的長(zhǎng)度
join Array.join(separator) 將數(shù)組各個(gè)元素是通過指定的分隔符進(jìn)行連接成為一個(gè)字符串
splice Array.splice(index, howmany, element1,.....,elementX) 用于插入、刪除或替換數(shù)組的元素。
  • splice函數(shù)分別實(shí)現(xiàn)push方法
var arr=new Array(1,2,3,4,5)
arr.push(100)
console.log(arr)         //[1, 2, 3, 4, 5, 100]
arr.splice(6,0,'jirengu')  //靈活的寫法arr.splice(arr.length,0,item)
console.log(arr)        //[1, 2, 3, 4, 5, 100, "jirengu"]
  • splice函數(shù)分別實(shí)現(xiàn)pop方法
var arr=new Array(1,2,3,4,5)
arr.pop()
console.log(arr)   //[1, 2, 3, 4]
arr.splice(3,1)      //靈活的寫法arr.splice(arr.length-1,1)
console.log(arr)   //[1, 2, 3]
  • splice函數(shù)分別實(shí)現(xiàn)shift方法
var arr=new Array(1,2,3,4,5)
arr.shift()           //1
console.log(arr)   //[2, 3, 4, 5]
arr.splice(0,1)
console.log(arr)   //[ 3, 4, 5]
  • splice函數(shù)分別實(shí)現(xiàn)unshift方法
var arr=new Array(1,2,3,4,5)
arr.unshift(100)      //6(數(shù)組長(zhǎng)度)
console.log(arr)   //[100,1, 2, 3, 4, 5]
arr.splice(0,0,'jirengu')
console.log(arr)   //["jirengu", 100, 1, 2, 3, 4, 5]
2. 寫一個(gè)函數(shù),操作數(shù)組,數(shù)組中的每一項(xiàng)變?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) // [4, 16, 36]
數(shù)組-2測(cè)試.png
3. 寫一個(gè)函數(shù),操作數(shù)組,返回一個(gè)新數(shù)組,新數(shù)組中只包含正數(shù),原數(shù)組不變
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 arr = [3, -1,  2,  '饑人谷', true]
var newArr = filterPositive(arr)
console.log(newArr) //[3, 2]
console.log(arr) //[3, -1,  2,  '饑人谷', true]
數(shù)組-3測(cè)試.png
ES5數(shù)組拓展
function filterPositive(arr){
  return arr.filter(function (value) {
    return (typeof value === "number") && ( value > 0);
  });
}
var arr = [3, -1,  2,  '饑人谷', true]
var newArr = filterPositive(arr)
console.log(newArr) //[3, 2]
console.log(arr)

Date

1. 寫一個(gè)函數(shù)getChIntv,獲取從當(dāng)前時(shí)間到指定日期的間隔時(shí)間
function getChIntv(dateStr){
    var targetDate = new Date(dateStr);
    var curDate = new Date();
    var offset = Math.abs(targetDate-curDate);
    var totalsecond = Math.floor(offset/1000);
    var seconds = totalsecond%60;
    var totalMinutes = Math.floor((offset/1000)/60);
    var mintues = totalMinutes%60;
    var totalHours = Math.floor(((offset/1000)/60)/60);
    var hours = totalHours%24;
    var totalDays = Math.floor((((offset/1000)/60)/60)/24);
    return '距除夕還有'+totalDays+'天'+hours+'小時(shí)'+mintues+'分鐘'+seconds+'秒';
}
var str = getChIntv("2018-02-15");
console.log(str);   // 距除夕還有156天9小時(shí)48分鐘23秒
date-1測(cè)試.png
2. 把hh-mm-dd格式數(shù)字日期改成中文日期
function getChsDate(date){
    var dict = ['零','一','二','三','四','五','六','七','八','九','十','十一','十二','十三','十四','十五','十六','十七','十八','十九','二十','二十一','二十二','二十三','二十四','二十五','二十六','二十七','二十八','二十九','三十','三十一'];
    var arr = [];
    var newArr = date.split('-');
    var year = newArr[0];
    for(var i = 0; i < year.length; i++){
        arr.push(dict[year[i]]);
    }
    arr.push("年");
    arr.push(dict[parseInt(newArr[1],10)]);
    arr.push("月");
    arr.push(dict[parseInt(newArr[2],10)]);
    arr.push("日");
    var newArr = arr.join('');
    return newArr
}
var str = getChsDate('2015-01-08');
console.log(str); // 二零一五年一月八日
date-2測(cè)試.png
3. 寫一個(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 targetDate = time;
    var curDate = new Date().getTime();
    var offset = Math.abs(targetDate-curDate);
    if(offset < 60*1000){
        return '剛剛'
    }else if(offset < 60*1000*60){
        return '3分鐘前'
    }else if(offset < 60*1000*60*24){
        return '8小時(shí)前'
    }else if(offset < 60*1000*60*24*30){
        return '3天前'
    }else if(offset < 60*1000*60*24*30*12){
        return '2個(gè)月前'
    }else if(offset >= 60*1000*60*24*30*12){
        return '8年前'
    }
}
var str1 = friendlyDate( '1494432000000' ) //  2017-5-11
 console.log(str1)
var str2 = friendlyDate('1504886400000')  //2017-9-09
console.log(str2)
date-3測(cè)試.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,786評(píng)論 6 534
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,656評(píng)論 3 419
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,697評(píng)論 0 379
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,098評(píng)論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,855評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,254評(píng)論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,322評(píng)論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,473評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,014評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,833評(píng)論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,016評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,568評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,273評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,680評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,946評(píng)論 1 288
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,730評(píng)論 3 393
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,006評(píng)論 2 374

推薦閱讀更多精彩內(nèi)容