第十四节 JavaScript数学对象和日期对象

2021-11-23  本文已影响0人  心存美好

一. Math对象

一般用来执行js中的数学运算

Math对象的方法

Math.PI 圆周率

Math.random() 获取随机数字 [0,1)

Math.min(a,b) a和b中取小值

Math.max(a,b) a和b中取大值

Math.ceil(x) 把x上取整

Math.floor(x) 把x下取整

Math.round(x) 把x四舍五入

Math.abs(x) 取x的绝对值

Math.sin(x) 求x的正弦值

Math.cos(x) 求x的余弦值

Math.tan(x) 求x的正切值

Math.pow(x,y) 求x的y次方

Math.sqrt(x) 求x的平方根

1. Math对象

Math是js的内置对象,可以直接使用,

检测Math是不是一个对象

console.log(typeof Math);
2.方法的使用
2.1 常用属性方法
// 获取圆周率 Math的属性PI
console.log(Math.PI);   

// Math的方法
// 1.随机数[0,1)
console.log(Math.random());

// 2.获取最小值,返回参数最小值
// 如果传入的参数不是数字类型,会转为数字类型,转不了也就比不来最小返回NaN
// 可以传一个参数
// 不传参为Infinity
console.log(Math.min(10,20,30,50))

// 3.获取最大值,返回参数最大值
// 可以传一个参数
// 不传参为-Infinity
console.log(Math.max(10,20,30,50));

// 4.向上取整
// 正常返回整数
// 接受一个参数,如果有多个参数,自动忽略后面的
// 如果传入的不是数字类型,隐式转换数字类型,转不了NaN
// 不传参,返回NaN
console.log(Math.ceil(2.3));

// 4.向下取整
// 正常返回整数
// 接受一个参数,如果有多个参数,自动忽略后面的
// 如果传入的不是数字类型,隐式转换数字类型,转不了NaN
// 不传参,返回NaN
console.log(Math.floor(2.3));

// 5.四舍五入
// 正常返回整数
// 接受一个参数,如果有多个参数,自动忽略后面的
// 如果传入的不是数字类型,隐式转换数字类型,转不了NaN
// 不传参,返回NaN
console.log(Math.round(2.3));

// 6.绝对值
// 正常返回正数
// 接受一个参数,如果有多个参数,自动忽略后面的
// 如果传入的不是数字类型,隐式转换数字类型,转不了NaN
// 不传参,返回NaN
console.log(Math.abs(2.3));
求一个数组内的最小值
var arr=[10,30,49,5,72,66,101]
var min =Math.min.apply(null,arr)//apply第一个参数为null表示不改变数组指向,第二个参数表示apply接收数组。Math.min接收的是数组中每一项的值
console.log(min);
2.2 其他方法
// 1. 求正弦值 
// Math.sin(弧度值)
console.log(Math.sin(Math.PI/6));

// 2. 求余弦值 
// Math.cos(弧度值)
console.log(Math.cos(Math.PI/6));

// 3. 求正切
// Math.tan(弧度值)
console.log(Math.tan(Math.PI/6));

// 4. x的y次幂
// Math.pow(x,y)    x的y次方
// 接受两个参数,传入多个忽略后面的
// 只传一个参数或不传就是NaN
// x,y支持负数
console.log(Math.pow(x,y));

// 4. 开方
// Math.sqrt(x)  
// 接受一个参数,传入多个忽略后面的
// 其他数据类型会转数字类型,转不了为NaN
// 不传就是NaN
console.log(Math.sqrt(x) );
随机验证码(有重复数字)
function unique(){
    var str = "0123456789abcdefghijklmnopqrstuvwsyzABCDEFGHIJKLMNOPQRSTUVWSYZ";
    var newStr = ""
    for(var i = 0; i < 4; i++){
        newStr += str[parseInt(Math.random()*str.length)];
    }
    return newStr;
}
随机验证码(无重复数字)
function unique(){
    var str = "0123456789abcdefghijklmnopqrstuvwsyzABCDEFGHIJKLMNOPQRSTUVWSYZ";
    var newStr = ""
    for(var i = 0; i < 4; i++){
        var randow = parseInt(Math.random()*str.length);
        if(newStr.indexOf(str[randow]) !== -1){
            i--;
            continue;
        }else{
            newStr += str[randow];
        }
        
    }
    return newStr;
}

二. 日期对象 Date

日期对象是JS中提供的用于控制年份日期.时间.的对象

1. 创建日期对象

Date是js内置的构造函数,使用前,先通过new操作符构造一个日期对象出来

var date = new Date();  
console.log(date);   // Fri Apr 26 2019 15:14:55 GMT+0800 (中国标准时间)

注意,这个获取时间不是实时的,是将此时此刻你获取的时间拍照报存在变量date中

2. 优化获取的时间

date.toLocaleString() ==> 获取本地日期字符串
date.toLocaleDateString() ==> 获取本地(年/月/日)形式的字符串
date.toLocaleTimeString() ==> 获取本地(时/分/秒)形式的字符串

2.1 本地日期格式
date.toLocaleString();     // "2019/4/26 下午3:17:33"
date.toLocaleDateString(); // "2019/4/26"
date.toLocaleTimeString(); // "下午3:17:33"
3. 日期对象的方法

3.1 日期对象的获取方法

date.getFullYear() ==>获取年份

date.getMonth() ==>获取月份 (0-11)

date.getDate() ==>获取日 (1-31)

date.getHours() ==>获取小时

date.getMinutes ==>获取分钟

date.getSeconds ==>获取秒钟

date.getMilliseconds ==>获取毫秒

date.getDay() ==>获取星期几 (0-6) 星期天是0

date.getTime() ==>获取当前时间到1970年1月1日午夜的毫秒数

date.getTimezoneOffset() ==> 获取当前时区的偏移时间 东8区是-480

// 1. 获取年份
date.getFullYear();   //2019

// 2. 获取月份
// 注意,月份的计数是从0开始的的,也就是1月份的数字为0,
// 所以获取月份数字后加1才是真正的月份
date.getMonth() + 1;    // 3 + 1 = 4  ,

// 3. 获取日期
date.getDate();   // 26

// 4. 获取小时
date.getHours();      // 10

// 5. 获取分钟
date.getMinutes();      // 30

// 6. 获取秒数
date.getSeconds();      // 20

// 7. 获取毫秒数
date.getMilliseconds();      // 862

// 8. 获取星期几
date.getDay();         //  5

// 9. 获取时间戳
date.getTime();       //1556264444841(1970年1月1日0时0分0秒到现在的毫秒数)

// 10. 获取格林威治时间与本地时间相差的分钟数
date.getTimezoneOffset();  // -480 时区偏移,我们是东八区
// 查看格林威治时间
date.setHours(date.getHours() + date.getTimezoneOffset()/60);
date.toLocaleString();

3.2 设置时间的方法

date.setFullYear() ==>设置年份

date.setMonth() ==>设置月份 (0-11)

date.setDate() ==>设置日 (1-31)

date.setHours() ==>设置小时

date.setMinutes() ==>设置分钟

date.setSeconds() ==>设置秒钟

date.setMilliseconds() ==>设置毫秒

// 1. 设置日期的年份
date.setFullYear(2017);     // 返回时间戳

// 2. 设置月份
// 注意如果你传入的参数大于11,将会减掉11,加一年,然后剩下的再修改月份
date.setMonth(10);         // 返回时间戳 

例子:

每隔一秒将当前时间打印子控制台上

setInterval(function(){
    var date = new Date();
    var YY = date.getFullYear();   //2019
    var MM = date.getMonth() + 1;
    var DD =  date.getDate();  
    var hh = date.getHours(); 
    var mm = date.getMinutes();    
    var ss = date.getSeconds();  
    console.log('现在的时间时'+YY+'年'+MM+'月'+DD+'日'+hh+'时'+mm+'分'+ss+'秒');
},1000)

写一个时钟并输出到页面上(获取一个时间戳,不会更新)

<div id="time">
  </div>
  <script>
    //写一个时钟并输出到页面上(获取一个时间戳,不会更新,只有刷新是更新)
    var date = new Date;
    var YYYY = date.getFullYear();
    var MM = date.getMonth();
    var DD = date.getDate();
    var hh = date.getHours();
    var mm = date.getMinutes();
    var ss = date.getSeconds();
    time.innerHTML += '当前的时间为:';//频繁操作DOM会影响性能
    time.innerHTML += YYYY + '年';
    time.innerHTML += MM +1 + '月';
    time.innerHTML += DD + '日';
    time.innerHTML += ' ';
    time.innerHTML += hh + '时';
    time.innerHTML += mm + '分';
    time.innerHTML += ss + '秒';
  </script>

写一个时钟并输出到页面上(使用定时器,每隔一秒会自动更新)

  <div id="time">
  </div>
  <script>
    function clock() {
      time.innerHTML ="";//每次清空DOM节点,不能累加
      var date = new Date;
      var YYYY = date.getFullYear();
      var MM = date.getMonth();
      var DD = date.getDate();
      var hh = date.getHours();
      var mm = date.getMinutes();
      var ss = date.getSeconds();
      time.innerHTML += '当前的时间为:' + YYYY + '年'+ ( MM +1 ) + '月' +DD + '日'+ ' ' + hh + '时' +mm + '分'+ss + '秒'; //这样写优点:只操作一次DOM
    }
    setInterval(clock,1000);//循环定时器
  </script>

写一个时钟并输出到页面上,JS中插入标签,定义字符串,给数字添加样式(使用定时器,每隔一秒会自动更新)

<style>
    #time span{
      color:red;
    }
  </style>
</head>
<body>
  <div id="time">
  </div>
  <script>
    function clock() {
      time.innerHTML = "";//每次清空DOM节点,不能累加
      var date = new Date;
      var YYYY = date.getFullYear();
      var MM = date.getMonth();
      var DD = date.getDate();
      var hh = date.getHours();
      var mm = date.getMinutes();
      var ss = date.getSeconds();
      var str = "";
      str +=  '当前的时间为:';
      str += '<span>' + YYYY + '</span>'+'年';
      str += '<span>' +(MM + 1)  + '</span>'+'月';//要加括号
      str += '<span>' + DD + '</span>'+'日';
      str += '<span>' + ' '+'</span>';
      str += '<span>' + hh + '</span>'+'时';
      str += '<span>' + mm + '</span>'+'分';
      str += '<span>' + ss + '</span>'+'秒';
      time.innerHTML = str;
    }
    setInterval(clock, 1000);//循环定时器
  </script>
4. 获取指定的时间

var date = new Date(参数) ==>获取指定时间
参数形式 ==>2019,1,5 2019年2月5日

// 获取指定的时间
var date = new Date(2019,1,5)    // ,写法
var date = new Date('2019-05-27 20:30:25');  // -写法
var date = new Date('2019/05/27 20:30:25');  // /写法


<script>
    var date = new Date;//获取当前此时此刻的时间戳
    console.log(date);
    date.setFullYear(1999)//通过设置时间戳获取指定时间戳
    console.log(date);
    //new Date() 可以传参,参数就是指定的时间戳
    var date2 = new Date(2021, 11, 30, 11, 30, 30)   //月份的值是减一的,这种数字参数的写法平时不用
    console.log(date2);
    var date3 = new Date('2022-11-30 15:3:30')//参数可以是字符串格式,就是日期格式.字符串月份不用减一.这种格式也行2022/11/30
    console.log(date3);
  </script>

5. 获取两个时间戳相差的毫秒数

两个时间戳相减是毫秒数
var date = new Date(2020,0,25);
var now = new Date();
var _date = date - now;     // _date的值是毫秒数


    var date = new Date();
    var date3 = new Date('2021-11-30 15:3:30')
    var _date = date3 - date;
    console.log("相差毫秒数 "+_date+" ms");
    console.log("相差天数 " + parseInt(_date/3600000/24)+" 天");
5.1 距离过年的时间
// 距离过年的天,时,分,秒
setInterval(function(){
    var day = Math.floor(_date/(1000*60*60*24));
    var hours = Math.floor(_date/(1000*60*60)%24);
    var minutes = Math.floor(_date/(1000*60)%60);
    var seconds = Math.floor(_date/(1000)%60);
},1000)

// toTwo
function toTwo(num){
    if(num < 10){
        return '0' + num;
    }else{
        return num;
    }
}
    <head>
      <style>
        #time span {
          color: red;
        }
      </style>
    </head>
    
    <body>
      <div id="time">
      </div>
      <script>
        //输出两位过年时间值
        var year = new Date("2021-11-30 00:01:01");
        function yearTime() {
          var now = new Date();
          var ms = year - now;
          var day = parseInt(ms / 1000 / 60 / 60 / 24);
          var hh = parseInt(ms / 1000 / 60 / 60 % 24);
          var mm = parseInt(ms / 1000 / 60 % 60);
          var ss = parseInt(ms / 1000 % 60);
          var str = "";
          str += "距离过年还有";
          str += "<span>" + toTwo(day) + "天" + "</span>" + "<span>" + toTwo(hh) + "</span>" + "时" + "<span>" + toTwo(mm) + "</span>" + "分" + "<span>" + toTwo(ss) + "</span>" + "秒";
          time.innerHTML = str;
        }
        //转成占两位函数
        function toTwo(num) {
          return (num >= 10 ? "" : "0") + num;
        }
        setInterval(yearTime, 1000)
      </script>
    </body>
上一篇 下一篇

猜你喜欢

热点阅读