js指定日期增加指定月份的实现方法


Posted in Javascript onDecember 19, 2018

前言

本文主要给大家介绍的是关于js实现指定日期增加指定月份的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

首先,大致思路为:

     1. 先将字符串格式的时间类型转化为Date类型

     2. 再将Date类型的时间增加指定月份

     3. 最后将Date类型的时间在转化为字符串类型

示例代码:

1. 先将字符串格式的时间类型转化为Date类型

var str = '2018-01-01 00:00:00'; //字符串格式的时间类型
 var str1 = str.replace(/-/g,'/'); //'2018/01/01 00:00:00'
 var date = new Date(Date.parse(str1)); //date格式的时间类型

2. 再将Date类型的时间增加指定月份

var nowDate = date.addMonth(3); //date格式的时间类型

Date.prototype.addMonth = function (addMonth) {
 var y = this.getFullYear();
 var m = this.getMonth();
 var nextY = y;
 var nextM = m;
 //如果当前月+要加上的月>11 这里之所以用11是因为 js的月份从0开始
 if ((m + addMonth)> 11) {
  nextY = y + 1;
  nextM = parseInt(m + addMonth) - 12;
 } else {
  nextM = this.getMonth() + addMonth
 }
 var daysInNextMonth = Date.daysInMonth(nextY, nextM);
 var day = this.getDate();
 if (day > daysInNextMonth) {
  day = daysInNextMonth;
 }
 return new Date(nextY, nextM, day);
 };
 Date.daysInMonth = function (year, month) {
 if (month == 1) {
  if (year % 4 == 0 && year % 100 != 0)
  return 29;
  else
  return 28;
 } else if ((month <= 6 && month % 2 == 0) || (month = 6 && month % 2 == 1))
  return 31;
 else
  return 30;
 };

3. 最后将Date类型的时间在转化为字符串类型

var nowStr = nowDate.format('yyyy-MM-dd hh:mm:ss'); //指定字符串格式的时间类型

Date.prototype.format = function (format) {
 var date = {
  "M+": this.getMonth() + 1,
  "d+": this.getDate(),
  "h+": this.getHours(),
  "m+": this.getMinutes(),
  "s+": this.getSeconds(),
  "q+": Math.floor((this.getMonth() + 3) / 3),
  "S+": this.getMilliseconds()
 };
 if (/(y+)/i.test(format)) {
  format = format.replace(RegExp.$1, (this.getFullYear() + '').substr(4 - RegExp.$1.length));
 }
 for (var k in date) {
  if (new RegExp("(" + k + ")").test(format)) {
  format = format.replace(RegExp.$1, RegExp.$1.length == 1
   ? date[k] : ("00" + date[k]).substr(("" + date[k]).length));
  }
 }
 return format;
 };

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
jquery tab插件制作实现代码
Jun 22 Javascript
JavaScript  cookie 跨域访问之广告推广
Apr 20 Javascript
JavaScript触发onScroll事件的函数节流详解
Dec 14 Javascript
Web制作验证码功能实例代码
Jun 19 Javascript
详谈vue+webpack解决css引用图片打包后找不到资源文件的问题
Mar 06 Javascript
axios封装,使用拦截器统一处理接口,超详细的教程(推荐)
May 02 Javascript
Vue3.0结合bootstrap创建多页面应用
May 28 Javascript
js实现select下拉框选择
Jan 11 Javascript
vue fetch中的.then()的正确使用方法
Apr 17 Javascript
vue双击事件2.0事件监听(点击-双击-鼠标事件)和事件修饰符操作
Jul 27 Javascript
微信小程序实现聊天室功能
Jun 14 Javascript
vue实现登陆页面开发实践
May 30 Vue.js
动态内存分配导致影响Javascript性能的问题
Dec 18 #Javascript
关于node-bindings无法在Electron中使用的解决办法
Dec 18 #Javascript
Makefile/cmake/node-gyp中区分判断不同平台的方法
Dec 18 #Javascript
JS监听滚动和id自动定位滚动
Dec 18 #Javascript
JS实现的tab页切换效果完整示例
Dec 18 #Javascript
CryptoJS中AES实现前后端通用加解密技术
Dec 18 #Javascript
antd组件Upload实现自己上传的实现示例
Dec 18 #Javascript
You might like
PHP持久连接mysql_pconnect()函数使用介绍
2012/02/05 PHP
逆序二维数组插入一元素的php代码
2012/06/08 PHP
Zend Framework实现自定义过滤器的方法
2016/12/09 PHP
php微信公众号开发(2)百度BAE搭建和数据库使用
2016/12/15 PHP
PHP中ajax无刷新上传图片与图片下载功能
2017/02/21 PHP
关于取不到由location.href提交而来的上级页面地址的解决办法
2009/07/30 Javascript
动态的创建一个元素createElement及删除一个元素
2014/01/24 Javascript
js脚本获取webform服务器控件的方法
2014/05/16 Javascript
原生javascript获取元素样式
2014/12/31 Javascript
js控制网页背景音乐播放与停止的方法
2015/02/06 Javascript
jQuery搜索同辈元素方法
2015/02/10 Javascript
AngularJS过滤器filter用法实例分析
2016/11/04 Javascript
微信小程序 本地数据读取实例
2017/04/27 Javascript
jQuery实现的页面遮罩层功能示例【测试可用】
2017/10/14 jQuery
Vue项目pdf(base64)转图片遇到的问题及解决方法
2018/10/19 Javascript
跟混乱的页面弹窗说再见
2019/04/11 Javascript
从0到1学习JavaScript编写贪吃蛇游戏
2020/07/28 Javascript
JavaScript 如何在浏览器中使用摄像头
2020/12/02 Javascript
[40:03]DOTA2上海特级锦标赛主赛事日 - 1 败者组第一轮#1EHOME VS Archon
2016/03/02 DOTA
[04:59]DOTA2-DPC中国联赛 正赛 Ehome vs iG 选手采访
2021/03/11 DOTA
在Python的Flask框架中构建Web表单的教程
2016/06/04 Python
django批量导入xml数据
2016/10/16 Python
Django视图和URL配置详解
2018/01/31 Python
将字典转换为DataFrame并进行频次统计的方法
2018/04/08 Python
Python 创建新文件时避免覆盖已有的同名文件的解决方法
2018/11/16 Python
python-pyinstaller、打包后获取路径的实例
2019/06/10 Python
python 将字符串完成特定的向右移动方法
2019/06/11 Python
pyqt5与matplotlib的完美结合实例
2019/06/21 Python
python中bs4.BeautifulSoup的基本用法
2019/07/27 Python
python使用scapy模块实现ARP扫描的过程
2021/01/21 Python
html5实现完美兼容各大浏览器的播放器
2014/12/26 HTML / CSS
阿里健康大药房:阿里自营网上药店
2017/08/01 全球购物
个人求职简历中英文自我评价
2013/12/16 职场文书
运动会跳远广播稿
2014/02/04 职场文书
2014年健康教育工作总结
2014/11/20 职场文书
三好学生主要事迹材料
2015/11/03 职场文书