一次代码审核,其中刚好遇见了一些知识点记录顺带整理一下吧

  • date对象是javascript语言中内置的数据类型,用于提供日期和时间的操作接口。
  • Date类型使用自UTC1970年1月1日0点开始经过的毫秒数来保存日期,它可以表示的时间范围是1970年1月1日0点前后的各1亿天。

概念性的东西请移步这个博主的文章,写的真好!

https://www.cnblogs.com/xiaohuochai/p/5663102.html

https://www.cnblogs.com/xiaohuochai/p/5663102.html

https://www.cnblogs.com/xiaohuochai/p/5663102.html


下面让我们来看一些函数实例

  • 每个Object对象都有 toLocaleString/toString/valueOf 这些方法。
  • 像其他对象一样,Date继承了Object并重写了这些方法。

由于 Date.valueOf 直接返回的是是日期的毫秒表示,所以我们可以通过 +new Date()获取

我们我们最好是用 Date.now(ES5新增方法) 而不是 Date.parse

const pre1 = Date.parse(new Date()); // 1517828782000 - 丢失了毫秒的信息
const pre2 = Date.now(new Date()); // 1517828814628
const pre3 = (+ new Date()); // 1517828814628
console.log(pre1, pre2, pre3);

要注意客户端时间和服务端时间的区别(精确的时间还是需要 后端 来做的)

const a = new Date();

这里的 a 最后的值是客户端的时间(注意,不是联网后的当天时间!!!!!!)

我一直蠢蠢地以为这会是 正确的时间。

它将会是本地客户端的时间。意即是说,若我脑残地把自己手机或者电脑时间改了,他就!!!!


关于时间函数的一些深入理解

此版块内容(copy至)源自:想看更多点我

Date对象属性描述(Object这一对象都有的东西)

  • constructor:返回创建此对象的Date函数的引用,可用于判断是否是 Date 对象
    const test = new Date();
    if (test.constructor === Array) {
    console.log("test is Array");
    };
    if (test.constructor === Date) {
    console.log("test is Date");
    } // 最后打出 test is Date
    Object.prototype.toString.call(new Date()) === '[object Date]' // true
  • prototype:使我们有能力向对象添加属性和方法
    Date.prototype.show = function() {
    console.log(this);
    }
    const a = new Date();
    a.show();

    需要注意的是这里不要乱用箭头函数哦。箭头函数的this。


Date对象的常用方法摘抄

const now = new Date()

  • getYear 注:ES3 之后此方法已经被 弃用
  • getDay 获取当前星期X (0-6, 0 代表星期天)
  • getFullYear 获取当前年份(4位, 1970-????)
  • getMonth 获取当前月份(0-11,0 代表1月)
  • getDate 获取当前日(1-31)
  • getHours 获取当前小时数(0-23)
  • getMinutes 获取当前分钟数(0-59)
  • getSeconds 获取当前秒数(0-59)
const a = new Date();
const o = (date) => {
return {
"noYear": date.getYear(), // 118
"year": date.getFullYear(), // 2018
"month": date.getMonth(), // 0(1月)
"date": date.getDate(), // 31
"hour": date.getHours(), // 20
"minutes": date.getMinutes(), // 18
"seconds": date.getSeconds() // 9
}
}
console.log(o(a));

关于一些时间的应用场景

  • 1.判断闰年
const isLeapYear = (...needles) => {
for (const obj of needles) {
if ((obj % 4 === 0 && obj % 100 !==0) || obj % 400 === 0) {
console.log(obj + "是闰年");
continue;
}
console.log(obj + "不是闰年");
}
}
isLeapYear(2004, 2000, 500);

complete.

关于JS的Date对象的探究的更多相关文章

  1. JavaScript基础17——js的Date对象

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. JS的Date对象、Math、包装类

    Date对象 在JS使用Date对象来表示时间  当前时间 var d = new Date();  指定时间 格式:月/日/年 时:分:秒 var e = new Date("02/16/ ...

  3. js实现小时钟,js中Date对象的使用?

    介绍一下js中Date对象的使用 dateObj = new Date() dateObj = new Date(dateValue) dateObj = new Date(year,month,da ...

  4. JS高级面试题思路(装箱和拆箱、栈和堆、js中sort()方法、.js中Date对象中的getMounth() 需要注意的、开发中编码和解码使用场景有哪些)

    1.装箱和拆箱: 装箱:把基本数据类型转化为对应的引用数据类型的操作: var num = 123 // num var objNum = new Num(123) // object console ...

  5. JS中Date对象getYear()方法和getFullYear()方法区别

    释义 JavaScript getFullYear() 方法 getFullYear() 方法可返回一个表示年份的 4 位数字. getYear() 语法 dateObject.getFullYear ...

  6. JS 的Date对象

    原文 http://www.cnblogs.com/towerking/p/3220410.html 一.获取Date对象 在JS中我们可以通过下面一段代码获取本地时间 var currentDate ...

  7. javascript得知 - js的Date对象函数

    js的Date功能很强大.通常使用. 首先获得当前的日期: var CurDate = new Date(); var Year = CurDate.getFullYear(); //年份(四位 例: ...

  8. js日期date对象

    js日期 日期对象的一些属性和方法 var date = new Date() date.toString() // "Tue Jan 29 2019 22:58:13 GMT+0800 ( ...

  9. js中Date()对象详解

    var myDate = new Date(); myDate.getYear(); //获取当前年份(2位) myDate.getFullYear(); //获取完整的年份(4位,1970-???? ...

随机推荐

  1. [原]NYOJ-小光棍数-458

    大学生程序代写 /http://acm.nyist.net/JudgeOnline/problem.php?pid=458 *题目458题目信息运行结果本题排行讨论区小光棍数 时间限制:1000 ms ...

  2. freeMarker(六)——程序开发指南入门

    学习笔记,选自freeMarker中文文档,译自 Email: ddekany at users.sourceforge.net 1.创建Configuration实例 首先,你应该创建一个 free ...

  3. Poj_1008--Maya Calendar

    一.Description 上周末,M.A. Ya教授对古老的玛雅有了一个重大发现.从一个古老的节绳(玛雅人用于记事的工具)中,教授发现玛雅人使用了一个一年有365天的叫做Haab的历法.这个Haab ...

  4. GSM/GPRS操作示例

    A6(GPRS)  博文转自安信科技: http://wiki.ai-thinker.com/gprs/examples 1.电话接收 相关指令 ATDxxxxx;//xxx为电话号码 示例 打电话 ...

  5. netty中的EventLoop和EventLoopGroup

    Netty框架的主要线程就是I/O线程,线程模型设计的好坏,决定了系统的吞吐量.并发性和安全性等架构质量属性. 一.Netty的线程模型 在讨论Netty线程模型时候,一般首先会想到的是经典的Reac ...

  6. MongoDB之二基础入门(window/linux安装启动)

    mongodb中有三元素:数据库,集合,文档,其中“集合”就是对应关系数据库中的“表”,“文档”对应“行”. 一window安装与启动 一. 下载 上MongoDB官网 ,下载页面:https://w ...

  7. STL string大小写 转换

    std::string data = "This is a sample string."; // convert string to upper case std::for_ea ...

  8. 关于使用sklearn进行数据预处理 —— 归一化/标准化/正则化

    一.标准化(Z-Score),或者去除均值和方差缩放 公式为:(X-mean)/std  计算时对每个属性/每列分别进行. 将数据按期属性(按列进行)减去其均值,并处以其方差.得到的结果是,对于每个属 ...

  9. HTML5小知识

    1.HTML5一种“妥协的”语法 2.特点: 标签不区分大小写 元素可以省略结束标签 元素属性可以省略属性值 属性的属性值可以不适用引号

  10. Socket对象以及异常

    1  socket构造器: public Socket() 创建一个Socket套接字 public Socket(InetAddress address,int port) 创建一个指定IP和端口的 ...