進階-任務(wù)6

Math任務(wù)

1.寫一個函數(shù),返回從min到max之間的隨機整數(shù),包括min不包括max

function getRandom(min, max) {
    return Math.floor(Math.random() * (max-min)) + min;
}

2.寫一個函數(shù),返回從min都max之間的隨機整數(shù),包括min包括max

function getRandom(min, max) {
    return Math.floor(Math.random() * (max-min+1)) + min;
}

3.寫一個函數(shù),生成一個長度為 n 的隨機字符串,字符串字符的取值范圍包括0到9,a到 z,A到Z。

function getRandStr(len){
  var ALPHABET = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
  ALPHABET += 'abcdefghijklmnopqrstuvwxyz';
  ALPHABET += '0123456789';
  var str = '';
  for (var i = 0; i < len; i++) {
    var rand = Math.floor(Math.random() * ALPHABET.length);
    str += ALPHABET[rand];
  }
  return str;
}
var str = getRandStr(10);

4.寫一個函數(shù),生成一個隨機 IP 地址,一個合法的 IP 地址為0.0.0.0~255.255.255.255

function getRandIP() {
  var arr = [];
  for (var i = 0; i < 4; i++) {
    arr[i] = getRandom(0,255);
  }
  return arr.join('.');
}
function getRandom(min, max) {
    return Math.floor(Math.random() * (max-min+1)) + min;
}
var ip = getRandIP()
console.log(ip)

5.寫一個函數(shù),生成一個隨機顏色字符串,合法的顏色為#000000~ #ffffff

function getRandColor(){
  var arr = [];
  for (var i = 0; i < 6; i++) {
    arr[i] = (getRandom(0,15)).toString(16);
  }
  return '#' + arr.join('');
}
function getRandom(min, max) {
    return Math.floor(Math.random() * (max-min+1)) + min;
}
var color = getRandColor()
console.log(color)

數(shù)組任務(wù)

1.數(shù)組方法里push、pop、shift、unshift、join、split分別是什么作用?用 splice函數(shù)分別實現(xiàn)push、pop、shift、unshift方法

  • push在數(shù)組的末端添加一個或多個元素,并返回添加新元素后的數(shù)組長度。
  • pop方法用于刪除數(shù)組的最后一個元素,并返回該元素。
  • shift方法用于刪除數(shù)組的第一個元素,并返回該元素。
  • unshift方法用于在數(shù)組的第一個位置添加元素,并返回添加新元素后的數(shù)組長度。
  • join方法以參數(shù)作為分隔符,將所有數(shù)組成員組成一個字符串返回。
  • split方法按照給定規(guī)則分割字符串,返回一個由分割出來的子字符串組成的數(shù)組。
arr.push(num) === arr.splice(arr.length, 0, num);
arr.pop() === arr.splice(arr.length-1, 1);
arr.shift() === arr.splice(0, 1);
arr.unshift(num) === arr.splice(0, 0, num);

2.寫一個函數(shù),操作數(shù)組,數(shù)組中的每一項變?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)

3.寫一個函數(shù),操作數(shù)組,返回一個新數(shù)組,新數(shù)組中只包含正數(shù),原數(shù)組不變

function filterPositive(arr){
    return arr.filter(function(n) {
        return typeof n === 'number' && n > 0;
    })
}
var arr = [3, -1,  2, '饑人谷', true]
var newArr = filterPositive(arr)
console.log(arr) //[3, 2]
console.log(newArr)

Date 任務(wù)

1. 寫一個函數(shù)getChIntv,獲取從當(dāng)前時間到指定日期的間隔時間

function getChIntv(str) {
  var newStr = str.split('-').join('/')
  var curr  = new Date()
  var then = new Date(newStr)
  var differ = (curr - then)/1000;
  if (differ > 0) {
    var tense = '已經(jīng)過去'
  }else {
    tense = '還有'
    differ = - differ
  }
  var days = parseInt(differ/(3600*24))
  var hours = parseInt(differ/3600%24)
  var mins = parseInt(differ/60%60)
  var second = parseInt(differ%60)
  return '距'+str+tense+days+'天'+hours+'小時'+mins+'分'+second+'秒'
}
var str = getChIntv("2017-03-13");
console.log(str);

2.把hh-mm-dd格式數(shù)字日期改成中文日期

function getChsDate(str) {
  var dict = ["零","一","二","三","四","五","六","七","八","九","十", "十一", "十二", "十三", "十四", "十五", "十六", "十七", "十八", "十九", "二十", "二十一", "二十二", "二十三", "二十四", "二十五", "二十六",  "二十七", "二十八", "二十九", "三十", "三十一"];
  var arr = str.split('-')
  var yearNum = arr[0].split('');
  var yearStr = '';
  for (var i = 0; i < yearNum.length; i++) {
    yearStr += dict[yearNum[i]];
  }
  console.log(yearStr)
  var monthNum = arr[1].split('');
  var monthStr = '';
  for (var i = 0; i < monthNum.length; i++) {
    if (i == 0 && monthNum[0] == '0') { continue; }
    monthStr += dict[monthNum[i]];
  }
  console.log(monthStr)
  var dayNum = arr[2].split('');
  var dayStr = '';
  for (var i = 0; i < dayNum.length; i++) {
    if (i == 0 && dayNum[0] == '0') { continue; }
    dayStr += dict[dayNum[i]];
  }
  console.log(dayStr)
  return yearStr+'年'+monthStr+'月'+dayStr+'日';

}
var str = getChsDate('2015-01-08');
console.log(str);

3.寫一個函數(shù),參數(shù)為時間對象毫秒數(shù)的字符串格式,返回值為字符串。假設(shè)參數(shù)為時間對象毫秒數(shù)t,根據(jù)t的時間分別返回如下字符串:

function friendlyDate(time){
  var curr = Date.now()
  var differ = (curr - time)/1000
  var show = ''
  var days = differ/3600/24
  if (days >= 1) {
    if (days < 30) {
      show = '3天前'
    }else if (days>30 && days/30<12) {
      show = '2個月前'
    }else {
      show = '8年前'
    }
  }else {
    var mins = differ/60;
    if (mins >= 60) {
      show = '8小時前'
    }else if (mins >= 1) {
      show = '3分鐘前'
    }else {
      show = '剛剛'
    }
  }
  return show
}
var str = friendlyDate( '1489393613872' ) //  剛剛
console.log(str)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

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

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