Math数组Date

1、写一个函数,返回从min到max之间的 随机整数,包括min不包括max

function minMax(min,max){
  return Math.floor(Math.random()*(max-min)+min)
}
var a=minMax(50,100)
console.log(a)

2.写一个函数,返回从min都max之间的 随机整数,包括min包括max

function minMax(min,max){
  return Math.floor(Math.random()*(max-min+1)+min)
}
var a=minMax(20,30)
console.log(a)

3.写一个函数,生成一个长度为 n 的随机字符串,字符串字符的取值范围包括0到9,a到 z,A到Z。

var dict=[0,1,2,3,4,5,6,7,8,9,'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z']
function rd(n){
  var arr=[]
  arr.length=n
  for(i=0;i<arr.length;i++){
    arr[i]=dict[Math.floor(Math.random()*dict.length)]
  }
  return arr.join('')
}
var str1=rd(29)
console.log(str1)

4 、写一个函数,生成一个随机 IP 地址,一个合法的 IP 地址为 0.0.0.0~255.255.255.255

function rdIp(){
  arr=new Array(4)
  for(var i=0;i<arr.length;i++){
    arr[i]=Math.floor(Math.random()*256)
  }
  return arr.join('.')
}
var a=rdIp()
console.log(a)

5、写一个函数,生成一个随机颜色字符串,合法的颜色为#000000~ #ffffff

function rdColor(){
  var dict=['0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'],color
  arr=new Array(6)
  for(var i=0;i<arr.length;i++){
    arr[i]=dict[Math.floor(Math.random()*dict.length)]
  }
  return color='#'+arr.join('')
}
console.log(rdColor())

1.数组方法里push、pop、shift、unshift、join、splice分别是什么作用?用 splice函数分别实现push、pop、shift、unshift方法。

  • push
    往数组最后面增添一个元素,会改变原数组 arr.push(要增加的元素);//返回增加的值

  • pop
    删除数组最后面的一个元素,改变原数组,arr.pop();//返回删除的值

  • shift
    删除数组最前面的一个元素,改变数组,arr.shift();//返回删除的值

  • unshift
    往数组最前面增添一个元素,改变原数组,arr.unshift(要增加的元素);//返回增加的值

  • join
    把数组中所有元素放入一个字符串,并且,可以指定分割符。
    arr.join('-')//返回字符串

  • splice
    splice 中文:拼接,结合。 在js中可以操作数组,增加/删除。
    用法:splice(index,howmany,item1,item2...)//返回删除的新数组
    其中index,起始位置,支持负数,负数就是倒序(负数时,第二个参数没用,只删除一次),(必选参数)
    howmany,删除多少次。(必选参数)
    items ,要增加的项目。(可选),改变原数组。

    • 容易和slice,split搞混(因为拼写有点像啊)
    • slice 切片,字符串和数组都可以用,a.slice(x,y)代表切片起始位置x和终止位置,支持负数。返回的是切片的字符串或者数组。
    • split,将字符串转换为数组,a.split(x,y) x选择字符串或正则表达式来作为分割线,并且会去掉他们,y,可选。该参数可指定返回的数组的最大长度。如果设置了该参数,返回的子串不会多于这个参数指定的数组。如果没有设置该参数,整个字符串都会被分割,不考虑它的长度。
  • 用splice实现push,pop,shift,unshift

var a=[1,2,3,4,5],b
a.push(6)
a.splice(a.length,0,4)
console.log(a)//和push一样
a.pop()
a.splice(-1,1)
console.log(a)//和pop一样
a.shift()
a.splice(0,1)
console.log(a)
a.unshift(1)
a.splice(0,0,1)
console.log(a)

2、写一个函数,操作数组,数组中的每一项变为原来的平方,在原数组上操作

var a=[1,2,3,4],b
b=a.map(function(x){return x*x})
console.log(b)
var a=[1,2,3,4]
function aa(a){
  for(var i=0;i<a.length;i++){
    a[i]=a[i]*a[i]
  }
  return a
}
console.log(aa(a))

3.写一个函数,操作数组,返回一个新数组,新数组中只包含正数,原数组不变

var a=[1,2,3,4,-1,0,2,5],b
b=a.filter(function(x){return x>0})
console.log(b)
var a=[1,2,3,4,-1,0,2,5]
function positiveNumber(arr){
  var b=[],j=0
  for(var i in arr){
    if(arr[i]>0){
      b[j]=arr[i]
      j++
    }
  }
  return b
}
console.log(positiveNumber(a))

1、 写一个函数getChIntv,获取从当前时间到指定日期的间隔时间

function getChlntv(x){
   var a=Date.parse(x)-Date.now()
   var b=1000*60*60*24
   var c=1000*60*60
   var d=1000*60
   var e=1000
   if(a>=0){
     console.log('距离'+x+'还有'+Math.floor(a/b)+'天'+Math.floor(a%b/c)+'小时'+Math.floor(a%b%c/d)+'分'+Math.floor(a%b%c%d%e)+'秒')
   } else{
    console.log('从'+x+'到如今,我们已经走过'+Math.floor((-a)/b)+'天'+Math.floor((-a)%b/c)+'小时'+Math.floor((-a)%b%c/d)+'分'+Math.floor((-a)%b%c%d/e)+'秒')
  }
}

2.把hh-mm-dd格式数字日期改成中文日期

var  str = getChsDate('2015-10-08');
  function getChsDate(str){
    var dict=        {'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 arr=str.split('-')
    console.log(arr)
    var strYear='',strMonth,strDay,Date
    for(var i=0;i<arr[0].length;i++){
      strYear+=dict[arr[0][i]]
    }
    console.log(strYear)
    if(arr[1][0]==='0'){
      strMonth=dict[arr[1][1]]
    }else{
      strMonth=dict[arr[1]]
    }
    console.log(strMonth+'月')
    if(arr[2][0]==='0'){
       strDay=dict[arr[2][1]]
    }else{
       strDay=dict[arr[2]]
    }
    console.log(strDay)
    return strYear+'年'+strMonth+'月'+strDay+'日'
  }
console.log(str)

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 abc(time){
  var a=Date.now()-time
  console.log(a)
  switch(true){
      case a<1000:
      return '刚刚'
      break;
    case 1000<=a<1000*60*60:
      return '3分钟前';
      break;
    case 1000*60*60<=a<1000*60*60*24:
      return '8小时前';
      break;
    case 1000*60*60*24<=a<1000*60*60*24*30:
      return '3天前'
      break;
    case 1000*60*60*24*30<=a<1000*60*60*24*30*12:
      return '8个月前';
      break;
    case a>=1000*60*60*24*30*12:
      return '8年前';
  }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容

  • .写一个函数,返回从min到max之间的 随机整数,包括min不包括max function randomness...
    邢烽朔阅读 311评论 0 1
  • 写一个函数,返回从min到max之间的 随机整数,包括min不包括max 写一个函数,返回从min都max之间的 ...
    LeeoZz阅读 301评论 0 0
  • Math任务 1、写一个函数,返回从min到max之间的随机整数,包括min不包括max
    湖衣阅读 259评论 0 0
  • 1.Math写一个函数,返回从min到max之间的 随机整数,包括min不包括max 2.写一个函数,返回从min...
    hellowade阅读 150评论 0 0
  • Math任务 一、写一个函数,返回从min到max之间的 随机整数,包括min不包括maxfunction ret...
    邵志远阅读 155评论 0 0