javascript 封装Date日期类实例详解


Posted in Javascript onMay 28, 2017

javascript-封装Date日期类

(一)对日期进行格式化

自定义Date日期类的format()格式化方法

方式一:(非原创)

// 对Date的扩展,将 Date 转化为指定格式的String
// 月(M)、日(d)、小时(H)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符, 
// 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字) 
// 例子: 
// (new Date()).Format("yyyy-MM-dd HH:mm:ss.S") ==> 2016-09-19 16:32:53.731
// (new Date()).Format("yyyy-M-d H:m:s:S")   ==> 2016-9-19 16:40:9:955 
Date.prototype.Format = function (fmt) { //author: meizz 
  var o = {
    "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+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
  for (var k in o)
  if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
  return fmt;
};

测试:

window.onload=function() {
  var date = new Date();
  var b = date.toLocaleDateString();//获取的格式为:2016年9月19日
  var d = date.toLocaleTimeString();//下午4:42:46
  var e = date.toLocaleString();//2016年9月19日 下午4:44:02
  var f = date.toDateString();//Mon Sep 19 2016
  var g = date.toUTCString();//Mon, 19 Sep 2016 08:45:42 GMT
  var h = date.toString();//Mon Sep 19 2016 16:46:23 GMT+0800 (中国标准时间)
  //自定义日期格式
  var c = date.Format("yyyy-MM-dd HH:mm:ss");//format()方法是自定义的
  document.getElementById("aa").value = c;
};

(二)根据日期返回本周周一和周日的日期

/**
 * 根据日期返回本周周一和周日的日期
 * @param day
 *   参数日期
 * @param num
 *   第几周
 * @return oneWeek
 *   周一,周日所在日期  
 */
function getWeekDate(day,num) {
  
  num = num || 0;
  // 返回值:周一和周日所在的日期
  var oneWeek = {};
  // 初始日期
  var initDate = "";
  // 截取年月日
  initDate = day.split(' ')[0];
  // ie兼容性问题,将yyyy-MM-dd转换成yyyy/MM/dd
  initDate = initDate.replace(/-/g,"/");
  // 将string转换成Date
  initDate = new Date(Date.parse(initDate));//格式只能是yyyy/MM/dd
  
  // 返回 day距离1970 年 1 月 1 日0时0分的毫秒数
  var nowTime = initDate.getTime(); 
  // 返回星期的某一天的数字: 0(周日) 到 6(周六)
  var weekNum = initDate.getDay();
  // 一天所代表的毫秒数
  var oneDayTime = 24 * 60 * 60 * 1000; 
  
  //显示周一
  var MondayTime = nowTime - (weekNum - 1) * oneDayTime ; 
  //显示周日
  var SundayTime = nowTime + (7 - weekNum) * oneDayTime ; 
  if (0 != num) {
    MondayTime += 7 * num * oneDayTime;
    SundayTime += 7 * num * oneDayTime;
  }
  
  //初始化日期时间
  var monday = new Date(MondayTime);
  var sunday = new Date(SundayTime);
  // formatDate是自定义的格式化方法
  monday = monday.formatDate('yyyy-MM-dd');
  sunday = sunday.formatDate('yyyy-MM-dd');
  
  oneWeek.Monday = monday;
  oneWeek.Sunday = sunday;
  
  return oneWeek;
}

 测试:

var week = getWeekDate('2017-05-27',0);    
console.log(week.Monday + "," + week.Sunday);

 注意:

 Date.parse()具有兼容性问题,低版本IE浏览器不支持"yyyy-MM-dd"转换成Date,只支持"yyyy/MM/dd"转换成日期。

 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
锋利的jQuery 要点归纳(二) jQuery中的DOM操作(下)
Mar 23 Javascript
jquery中插件实现自动添加用户的具体代码
Nov 15 Javascript
javascript eval(func())使用示例
Dec 05 Javascript
IE的事件传递-event.cancelBubble示例介绍
Jan 12 Javascript
JS中捕获console.log()输出的方法
Apr 16 Javascript
jQuery Validate验证框架经典大全
Sep 23 Javascript
jQuery的Read()方法代替原生JS详解
Nov 08 Javascript
node跨域转发 express+http-proxy-middleware的使用
May 31 Javascript
Electron中实现大文件上传和断点续传功能
Oct 28 Javascript
vue组件之间通信方式实例总结【8种方式】
Feb 22 Javascript
Paypal支付不完全指北
Jun 04 Javascript
vue实现滚动鼠标滚轮切换页面
Dec 13 Vue.js
Vue实现选择城市功能
May 27 #Javascript
使用 Node.js 对文本内容分词和关键词抽取
May 27 #Javascript
vue子组件使用自定义事件向父组件传递数据
May 27 #Javascript
javascript回调函数的概念理解与用法分析
May 27 #Javascript
原生JavaScript实现的简单省市县三级联动功能示例
May 27 #Javascript
原生JavaScript实现精美的淘宝轮播图效果示例【附demo源码下载】
May 27 #Javascript
详细讲解vue2+vuex+axios
May 27 #Javascript
You might like
php 字符转义 注意事项
2009/05/27 PHP
linux命令之调试工具strace的深入分析
2013/06/03 PHP
php生成图片验证码-附五种验证码
2015/08/19 PHP
YII框架常用技巧总结
2019/04/27 PHP
javascript实现轮显新闻标题链接
2007/08/13 Javascript
Javascript 检测、添加、移除样式(className)函数代码
2009/09/08 Javascript
解决IE6的PNG透明JS插件使用介绍
2013/04/17 Javascript
JavaScript原型及原型链终极详解
2016/01/04 Javascript
通过JS和PHP两种方法判断用户请求时使用的浏览器类型
2016/09/01 Javascript
简单的渐变轮播插件
2017/01/12 Javascript
jQuery操作css样式
2017/05/15 jQuery
vuex的使用及持久化state的方式详解
2018/01/23 Javascript
浅谈node.js 命令行工具(cli)
2018/05/10 Javascript
AngularJS发送异步Get/Post请求方法
2018/08/13 Javascript
js replace替换字符串同时替换多个方法
2018/11/27 Javascript
利用原生JavaScript实现造日历轮子实例代码
2019/05/08 Javascript
vue使用codemirror的两种用法
2019/08/27 Javascript
vue单文件组件无法获取$refs的问题
2020/06/24 Javascript
[35:27]完美世界DOTA2联赛循环赛 GXR vs FTD BO2第二场 10.29
2020/10/29 DOTA
利用soaplib搭建webservice详细步骤和实例代码
2013/11/20 Python
python中的set实现不重复的排序原理
2018/01/24 Python
将Python字符串生成PDF的实例代码详解
2019/05/17 Python
对python中UDP,socket的使用详解
2019/08/22 Python
Python使用jpype模块调用jar包过程解析
2020/07/29 Python
美国儿童运动鞋和服装零售商:Kids Foot Locker
2017/08/05 全球购物
缅甸网上购物:Shop.com.mm
2017/12/05 全球购物
LACOSTE波兰官网:Polo衫、服装和鞋类
2020/09/29 全球购物
饲料采购员岗位职责
2013/12/19 职场文书
中国文明网签名寄语
2014/01/18 职场文书
模具专业毕业生自荐书范文
2014/02/19 职场文书
中学生演讲稿
2014/04/26 职场文书
离婚案件答辩状
2015/05/22 职场文书
网络妈妈观后感
2015/06/08 职场文书
《神奇的鸟岛》教学反思
2016/02/22 职场文书
vue实现滑动解锁功能
2022/03/03 Vue.js
Anaconda安装pytorch和paddle的方法步骤
2022/04/03 Python