JS 기본 - 수학 배열 날짜

jacklove
풀어 주다: 2018-05-21 17:06:32
원래의
2019명이 탐색했습니다.

이 글에서는 js의 기본적인 수학 배열과 날짜 관련 지식을 설명합니다.

1. Math

1. min은 포함하지만 max는 포함하지 않고 min과 max 사이의 임의의 정수를 반환하는 함수를 작성하세요.

   //不包含最大数
    function getNum(min,max){      //包含最小值,随机最小值与最大值之间的整数且不包含最大值
      console.log(min+Math.floor(Math.random()*(max-min)))
    }
      getNum(10,15)
로그인 후 복사

2 min과 max 사이의 임의의 정수를 반환하는 함수를 작성하세요.

//최대 개수도 포함

   function getNum2(min,max){    //包含最小值,随机最小值与最大值之间的整数且包含最大值
     console.log(min+Math.floor(Math.random()*(max+1-min)))
}
    getNum2(10,15)
로그인 후 복사

3. 길이가 n인 임의의 문자열을 생성하는 함수를 작성하세요. 문자열 문자의 값 범위에는 0~9, a~z, A~Z가 포함됩니다.

 function getRandStr(len){    //补全函数
     var str1=''
     var str = &#39;0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ&#39;;     for(var i=0;i<len;i++){       var ss=parseInt(Math.random()*str.length);
           str1 += str[ss];
     }     return str1
  }  var str = getRandStr(10); // 例:0a3iJiRZap
  console.log(str);
로그인 후 복사

4. 유효한 IP 주소는 0.0.0.0~255.255.255.255

 function getRandIP(){    //补全
    var ip=&#39;&#39;
    for (var i=0; i<4; i++){      var str=Math.floor(Math.random()*256);
      ip += str;      // 3个点是4个数
      if( i<3 ){
         ip += ".";
      }
   }   return ip;
 }var ip = getRandIP()console.log(ip) // 例:10.234.121.45
로그인 후 복사

5 이며, 유효한 색상은 #000000 ~ # 입니다. ffffff

 function getRandColor(){    var str = "0123456789abcdef";    var strlen = str.length;    var colorstr = "#";    for(var i = 0; i < 6; i++){      var index = Math.floor(Math.random()*strlen);
      colorstr += str[strlen];
    }    return colorstr
  }  var color = getRandColor()  console.log(color)   // 例:#3e2f1b
로그인 후 복사

2. Array

1. 배열방식에서 push, pop, shift, unshift, Join, Splice 기능은 무엇인가요? push, pop, Shift 및 unshift 메소드를 각각 구현하려면 splice 함수를 사용하십시오.

push(), pop() 및 unshift(), Shift()는 모두 배열에 대한 작업이며 길이와 내용을 변경합니다. 배열 자체.
차이점은 push()와 pop()은 배열의 꼬리에서 추가 및 삭제하는 반면, unshift()와 Shift()는 배열의 선두에서 추가 및 삭제한다는 것입니다.

splice() 메서드는 배열에 항목을 추가/제거하고 제거된 항목을 반환합니다. 이 메서드는 원래 배열을 변경합니다.
join() 메서드는 배열의 모든 요소를 ​​문자열에 넣는 데 사용됩니다. 요소는 지정된 구분 기호로 구분됩니다.

//splice函数分别实现push、pop、shift、unshift方法//例子:
  var arr = [1,2,3,4,5]  //push  
  arr.splice(arr.length,0,6); //位置,要删除元素的个数,要添加到数组的元素
  console.log(arr);//[1,2,3,4,5,6]
  console.log(arr.length)  //pop
  arr.splice(arr.length-1,1)  console.log(arr);//[1,2,3,4,5]
  //shift
  arr.splice(0,1);  console.log(arr);//[2,3,4,5]
  //unshift
  arr.splice(0,0,1);  console.log(arr);//[1,2,3,4,5]
로그인 후 복사

2. 배열의 각 항목이 원래의 정사각형이 되어 원래 배열에 대해 연산을 수행하는 함수를 작성하세요.

 function squareArr(arr){     for(var i = 0; i < arr.length; i++ ){
      arr[i] *= arr[i]
     }     return arr;
   }   var arr = [2, 4, 6]
   squareArr(arr)   console.log(arr) // [4, 16, 36]
로그인 후 복사

3. 배열을 연산하고 새 배열만 반환하는 함수를 작성하세요. 양수를 포함하면 원래 배열은 변경되지 않습니다.

  function filterPositive(arr){     var newArr = [];     for(var i = 0; i < arr.length; i++){       if(typeof(arr[i]) === "number" && arr[i] > 0){
         newArr.push(arr[i]);
       }
    }   return newArr;
  }  var arr = [3, -1,  2,  &#39;饥人谷&#39;, true]  var newArr = filterPositive(arr)  console.log(newArr) //[3, 2]
로그인 후 복사

Three.Date

1. 현재 시간부터 지정된 날짜까지의 간격을 가져오는 함수 getChIntv를 작성하세요

  function getChIntv(s) {     //时间=指定时间-当前时间
     var time = Math.abs(Date.parse(s) - Date.now()); 
     //天数=时间/天的毫秒
     var days = parseInt(time/(1000*60*60*24));     //几小时=时间%天的毫秒/一小时毫秒
     var hours = parseInt((time%(1000*60*60*24))/(1000*60*60));  
     //几分钟=时间%天的毫秒/一小时毫秒/一分钟毫秒
     var minutes = parseInt(((time%(1000*60*60*24))%(1000*60*60))/(1000*60)); 
    //几秒=时间%天的毫秒/一小时毫秒/一分钟毫秒/一秒毫秒
     var seconds = parseInt(((time%(1000*60*60*24))%(1000*60*60))%(1000*60)/1000); 
     return days + &#39;天&#39; + hours + &#39;小时&#39; + minutes + &#39;分钟&#39; + seconds+ &#39;秒&#39;
   }   var str = getChIntv(&#39;2017-7-01&#39;); 
   console.log(str);
로그인 후 복사

2. hh-mm-dd 형식의 디지털 날짜를 변경하세요. 중국 날짜로

 function getChsDate(s) {    
 var arr = [&#39;零&#39;,&#39;一&#39;,&#39;二&#39;,&#39;三&#39;,&#39;四&#39;,&#39;五&#39;,&#39;六&#39;,&#39;七&#39;,&#39;八&#39;,&#39;九&#39;,&#39;十&#39;,&#39;十一&#39;,&#39;十二&#39;,&#39;十三&#39;    , &#39;十四&#39;,&#39;十五&#39;,&#39;十六&#39;,&#39;十七&#39;,&#39;十八&#39;,&#39;十九&#39;,&#39;二十&#39;,&#39;二十一&#39;,&#39;二十二&#39;,&#39;二十三&#39;,&#39;二十四&#39;,     &#39;二十五&#39;,&#39;二十六&#39;,&#39;二十七&#39;,&#39;二十八&#39;,&#39;二十九&#39;,&#39;三十&#39;,&#39;三十一&#39;]    //字符串拆成数组     var time = s.split(&#39;-&#39;);    // 输出字符串就行    var year = time[0];   
 var month = time[1]; 
   var day = time[2];  
  var newYear = arr[year[0]]+arr[year[1]]+arr[year[2]]; 
   var newMonth = arr[parseInt(month)]; 
   var newDay = arr[parseInt(day)];   
 return newYear+"年"+newMonth+"月"+newDay+"日";  }  var str = getChsDate(&#39;2017-06-30&#39;);  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 friendlyDate(time){     var msec=new Date()     // getTime()返回距 1970 年 1 月 1 日之间的毫秒数
     var nowTime=msec.getTime()     var sec=(nowTime-time)/1000
     if(sec<60){        return &#39;刚刚&#39;
     }else if(sec>=60&&sec<3600){        return &#39;三分钟前&#39;
     }else if(sec>=3600&&sec<8*3600){        return &#39;8小时前&#39;
     }else if(sec>=24*3600&&sec<24*3600*30){        return &#39;3天前&#39;
     }else if(sec>=24*3600*30&&sec<24*3600*30*12){        return &#39;2个月前&#39;
     }else if(sec>=24*3600*30*12){               return &#39;8年前&#39;     
    }
   }   var str = friendlyDate( &#39;1484286699422&#39; ) 
   var str2 = friendlyDate(&#39;1483941245793&#39;) 
   console.log(str)  //2个月前
   console.log(str2) //2个月前
로그인 후 복사

이 글은 js의 기본에 관련된 글입니다. 관련 지식에 대한 설명은 php를 참고해주세요. 더 많은 지식을 얻으려면 중국어 웹사이트를 방문하세요.

관련 권장 사항:

jQuery는 무엇을 할 수 있나요?

프런트 엔드 교차 도메인 요약에 대한 관련 지식 포인트

프런트 엔드에 대한 일반적인 교차 도메인 솔루션(모두)

위 내용은 JS 기본 - 수학 배열 날짜의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!