JS对时间的操作

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS对时间的操作相关的知识,希望对你有一定的参考价值。

      JS时间操作大全

       1、获取每个月的开始和结束。

       2、获取每个季度的开始和结束。

       3、获取当前季度。

       4、把日期转换为字符串(支持各种格式)

           ...

       5、未完待续,不断添加

        

 String.prototype.padingStar=function(totalLength,padingStr="") {
            if (totalLength <= this.length) {
                return this;
            }
            var padLength = totalLength - this.length;
            if (padLength <= padingStr.length) {
                return padingStr.substring(0, padLength) + this;
            } else {
                var len = padLength / padingStr.length, n = 1,str=‘‘;
                while (n<len) {
                    str += padingStr;
                    n++;
                }
                return str + padingStr.substring(0, padLength - (n-1) * padingStr.length) +this;
            }
        }

        String.prototype.padingEnd = function (totalLength, padingStr="") {
            //在开始的补全后面
            if (totalLength <= this.length) {
                return this;
            }
            var padLength = totalLength - this.length;
            if (padLength <= padingStr.length) {
                return padingStr.substring(0, padLength) + this;
            } else {
                var len = padLength / padingStr.length, n = 0,str=‘‘;
                while (n<len) {
                    str += padingStr;
                    n++;
                }
                return this + padingStr.substring(0, padLength - (n - 1) * padingStr.length)+str;
            }
        }


        //获取当前月的开始
        Date.prototype.starOfMonth=function() {
            return new Date(this.getFullYear(), this.getMonth(), 1, 00, 00, 00);
        }

        //获取当前月的结束
        Date.prototype.endOfMonth=function() {
            return new Date(this.getFullYear(), this.getMonth() + 1, 0, 23, 59, 59);
        }

        //获取当前季度的开始时间
        Date.prototype.starofQuarter=function() {
            return new Date(this.getFullYear(), (this.getQuarter() - 1) * 3, 01, 00, 00, 00);
        }

        //获取当前季度的结束时间
        Date.prototype.endofQuarter=function() {
            return new Date(this.getFullYear(), this.getQuarter() * 3-1 , 31, 23, 59, 59);
        }

        //获取当前时间对应的季度
        Date.prototype.getQuarter=function() {
            return Math.ceil((this.getMonth() + 1) / 3);
        }

        //获取当前时间对应的年的开始
        Date.prototype.starOfYear=function() {
            return new Date(this.getFullYear(), 01, 01, 00, 00, 00);
        } 

        //获取当前时间对应年的结束
        Date.prototype.endOfYear=function() {
            return new Date(this.getFullYear(), 12, 31, 23, 59, 59);
        }

        //把时间格式化为字符串
        Date.prototype.toDateString = function(format) {
            if (typeof (format) == "undefined") {
                return this.toString();
            }
            //可能我的第一个想法,就是
            if (/y{4}/.test(format)) {
                format = format.replace(/yyyy/g, this.getFullYear());
            }
            if (/y{2}/.test(format)) {
                format = format.replace(/y{2}/g,this.getFullYear().toString().substr(2));
            }
            if (/M{2}/.test(format)) {
                format = format.replace(/MM/,this.getMonth().toString().padingStar(2,0));
            }
            if (/dd/.test(format)) {
                format = format.replace(/dd/,this.getDate().toString().padingStar(2,‘0‘));
            }
            if (/HH/.test(format)) {
                format = format.replace(/HH/g, this.getHours().toString().padingStar(2, ‘0‘));
            }
            if (/hh/.test(format)) {
                format = format.replace(/hh/g, (hour < 12 ? hour : hour - 12).toString().padingStar(2, ‘0‘));
            }
            if (/mm/.test(format)) {
                format = format.replace(/mm/g, this.getMinutes().toString().padStart(2, ‘0‘));
            }
            if (/ss/.test(format)) {
                format = format.replace(/ss/g, this.getSeconds().toString().padStart(2, ‘0‘));
            }
            return format;
        }

        
        //获取两个时间相隔的天数
        Date.prototype.betweenDays=function(date) {
            var daySpan = (Date.parse(this) - Date.parse(date)) / 86400000;
            return daySpan;
        }

       github地址:https://github.com/gdoujkzz/JsDate.git

    

以上是关于JS对时间的操作的主要内容,如果未能解决你的问题,请参考以下文章

XSS:如何从 C# 中的字符串中删除 JS 片段?

setOnItemClickListener没有对点击片段进行任何操作

js常用代码片段(更新中)

VSCode自定义代码片段——JS中的面向对象编程

谷歌浏览器调试jsp 引入代码片段,如何调试代码片段中的js

VSCode自定义代码片段9——JS中的面向对象编程