進(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測試.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測試.png
3. 寫一個(gè)函數(shù)脸秽,生成一個(gè)長度為 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測試
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測試.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測試.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è)元素,并返回(對空數(shù)組則返回undefined
shift Array.shift() 將數(shù)組的第一個(gè)元素從原數(shù)組中刪除霞捡,并返回被刪除的元素的值(對空數(shù)組則返回undefined
unshift Array.unshift(str) 向數(shù)組的頭部添加一個(gè)或更多元素坐漏,并返回新的長度
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ù)組長度)
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測試.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測試.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測試.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測試.png
3. 寫一個(gè)函數(shù)猖辫,參數(shù)為時(shí)間對象毫秒數(shù)的字符串格式酥泞,返回值為字符串。假設(shè)參數(shù)為時(shí)間對象毫秒數(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測試.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末悯姊,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子贩毕,更是在濱河造成了極大的恐慌悯许,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,402評論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件耳幢,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)睛藻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評論 3 392
  • 文/潘曉璐 我一進(jìn)店門启上,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人店印,你說我怎么就攤上這事冈在。” “怎么了按摘?”我有些...
    開封第一講書人閱讀 162,483評論 0 353
  • 文/不壞的土叔 我叫張陵包券,是天一觀的道長。 經(jīng)常有香客問我炫贤,道長溅固,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,165評論 1 292
  • 正文 為了忘掉前任兰珍,我火速辦了婚禮侍郭,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘掠河。我一直安慰自己亮元,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評論 6 388
  • 文/花漫 我一把揭開白布唠摹。 她就那樣靜靜地躺著爆捞,像睡著了一般。 火紅的嫁衣襯著肌膚如雪勾拉。 梳的紋絲不亂的頭發(fā)上煮甥,一...
    開封第一講書人閱讀 51,146評論 1 297
  • 那天,我揣著相機(jī)與錄音望艺,去河邊找鬼苛秕。 笑死,一個(gè)胖子當(dāng)著我的面吹牛找默,可吹牛的內(nèi)容都是我干的艇劫。 我是一名探鬼主播,決...
    沈念sama閱讀 40,032評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼惩激,長吁一口氣:“原來是場噩夢啊……” “哼店煞!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起风钻,我...
    開封第一講書人閱讀 38,896評論 0 274
  • 序言:老撾萬榮一對情侶失蹤顷蟀,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后骡技,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鸣个,經(jīng)...
    沈念sama閱讀 45,311評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡羞反,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了囤萤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片昼窗。...
    茶點(diǎn)故事閱讀 39,696評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖涛舍,靈堂內(nèi)的尸體忽然破棺而出澄惊,到底是詐尸還是另有隱情,我是刑警寧澤富雅,帶...
    沈念sama閱讀 35,413評論 5 343
  • 正文 年R本政府宣布掸驱,位于F島的核電站,受9級特大地震影響没佑,放射性物質(zhì)發(fā)生泄漏毕贼。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評論 3 325
  • 文/蒙蒙 一图筹、第九天 我趴在偏房一處隱蔽的房頂上張望帅刀。 院中可真熱鬧,春花似錦远剩、人聲如沸扣溺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽锥余。三九已至,卻和暖如春痢掠,著一層夾襖步出監(jiān)牢的瞬間驱犹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評論 1 269
  • 我被黑心中介騙來泰國打工足画, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留雄驹,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,698評論 2 368
  • 正文 我出身青樓淹辞,卻偏偏與公主長得像医舆,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子象缀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評論 2 353

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