進(jìn)階任務(wù)6:Math數(shù)組Date

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);

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1、寫(xiě)一個(gè)函數(shù),返回從min到max之間的隨機(jī)整數(shù),包括min不包括max 2、寫(xiě)一個(gè)函數(shù),返回從min都max之...
    osborne閱讀 300評(píng)論 0 0
  • Math任務(wù) 1、寫(xiě)一個(gè)函數(shù),返回從min到max之間的 隨機(jī)整數(shù),包括min不包括max 2、寫(xiě)一個(gè)函數(shù),返回從...
    我七閱讀 382評(píng)論 0 0
  • Math任務(wù) 1、寫(xiě)一個(gè)函數(shù),返回從min到max之間的 隨機(jī)整數(shù),包括min不包括max 2、寫(xiě)一個(gè)函數(shù),返回從...
    cheneyzhangch閱讀 312評(píng)論 0 0
  • 第5章 引用類(lèi)型(返回首頁(yè)) 本章內(nèi)容 使用對(duì)象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類(lèi)型 使用基本類(lèi)型...
    大學(xué)一百閱讀 3,679評(píng)論 0 4
  • 第一章 當(dāng)一個(gè)人在一個(gè)地方呆了五百年,身邊只有草,樹(shù)和石頭的時(shí)候,你會(huì)發(fā)現(xiàn)最要命的事情并不是五百年來(lái)一成不變的食譜...
    自在放下閱讀 258評(píng)論 0 0

友情鏈接更多精彩內(nèi)容