JS获取月的第几周和年的第几周实例代码


Posted in Javascript onDecember 05, 2018

下面一段代码给大家介绍JS获取月的第几周和年的第几周,具体代码如下所述:

var getMonthWeek = function (a, b, c) {
      /*
      a = d = 当前日期
      b = 6 - w = 当前周的还有几天过完(不算今天)
      a + b 的和在除以7 就是当天是当前月份的第几周
      */
      var date = new Date(a, parseInt(b) - 1, c), w = date.getDay(), d = date.getDate();
      return Math.ceil(
        (d + 6 - w) / 7
      );
    };
    var getYearWeek = function (a, b, c) {
      /*
      date1是当前日期
      date2是当年第一天
      d是当前日期是今年第多少天
      用d + 当前年的第一天的周差距的和在除以7就是本年第几周
      */
      var date1 = new Date(a, parseInt(b) - 1, c), date2 = new Date(a, 0, 1),
        d = Math.round((date1.valueOf() - date2.valueOf()) / 86400000);
      return Math.ceil(
        (d + ((date2.getDay() + 1) - 1)) / 7
      );
    };
    //获取时间的代码就不写了
    console.log(getMonthWeek(2019,1,1));//返回1

 补充:js 获取每月有几周,当前时间在当月第几周,今天周几等方法

 因产品需要展示相关时间,现总结如下方法:以供日后参考:

获取每月有几周

// year:年 month:月 day:日
 getWeeks(year, month, day) {
  const d = new Date()
  // 该月第一天
  d.setFullYear(2018, 6, 1)
  let w1 = d.getDay()
  if (w1 === 0) {
   w1 = 7
  }
  // 该月天数
  d.setFullYear(2018, 7, 0)
  const dd = d.getDate()
  // 该月第一个周一
  let d1
  if (w1 !== 1) {
   d1 = 7 - w1 + 2
  } else {
   d1 = 1
  }
  const WEEK_NUB = Math.ceil((dd - d1 + 1) / 7)
  return WEEK_NUB
 }

获得周期名字

getWeekName() {
 const weekday = ['周日', '周一', '周二', '周三', '周四', '周五', '周六']
 const index = new Date().getDay()
 const currDay = weekday[index]
 return currDay
}

获得当前日期在当月第几周

// a: 年 b: 月 c: 日 (不包括跟上个月重合的部分)
  getMonthWeek(a, b, c) {
   const date = new Date(a, parseInt(b) - 1, c)
   const w = date.getDay()
   const d = date.getDate()
   return Math.ceil(
    (d + 6 - w) / 7
   )
  }

总结

以上所述是小编给大家介绍的JS获取月的第几周和年的第几周实例代码 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
基于jquery的下拉框改变动态添加和删除表格实现代码
Sep 12 Javascript
html的DOM中Event对象onblur事件用法实例
Jan 21 Javascript
整理AngularJS中的一些常用指令
Jun 16 Javascript
JavaScript实现上下浮动的窗口效果代码
Oct 12 Javascript
高效利用Angular中内置服务$http、$location等
Mar 22 Javascript
全面了解构造函数继承关键apply call
Jul 26 Javascript
JS禁止查看网页源代码的实现方法
Oct 12 Javascript
Bootstrap如何创建表单
Oct 21 Javascript
浅谈VueJS SSR 后端绘制内存泄漏的相关解决经验
Dec 20 Javascript
Vue 设置axios请求格式为form-data的操作步骤
Oct 29 Javascript
微信小程序监听用户登录事件的实现方法
Nov 11 Javascript
node.js中npm包管理工具用法分析
Feb 14 Javascript
JavaScript实现学生在线做题计时器功能
Dec 05 #Javascript
vue-cli3搭建项目的详细步骤
Dec 05 #Javascript
详解vue中async-await的使用误区
Dec 05 #Javascript
Vue中的基础过渡动画及实现原理解析
Dec 04 #Javascript
使用FormData实现上传多个文件
Dec 04 #Javascript
vue自定义指令的创建和使用方法实例分析
Dec 04 #Javascript
用vuex写了一个购物车H5页面的示例代码
Dec 04 #Javascript
You might like
php 记录进行累加并显示总时长为秒的结果
2011/11/04 PHP
html静态页面调用php文件的方法
2014/11/13 PHP
ThinkPHP实现动态包含文件的方法
2014/11/29 PHP
PHP二维数组实现去除重复项的方法【保留各个键值】
2017/12/21 PHP
Laravel框架基于中间件实现禁止未登录用户访问页面功能示例
2019/01/17 PHP
js removeChild 障眼法 可能出现的错误
2009/10/06 Javascript
JavaScript中的面向对象介绍
2012/06/30 Javascript
js添加table的行和列 具体实现方法
2013/07/22 Javascript
js中的屏蔽的使用示例
2013/07/30 Javascript
jQuery实现图片放大预览实现原理及代码
2013/09/12 Javascript
原生js事件的添加和删除的封装
2014/07/01 Javascript
Node.js项目中调用JavaScript的EJS模板库的方法
2016/03/11 Javascript
JS当前页面登录注册框,固定DIV,底层阴影的实例代码
2016/09/29 Javascript
vue如何从接口请求数据
2017/06/22 Javascript
通过示例彻底搞懂js闭包
2017/08/10 Javascript
webpack vue 项目打包生成的文件,资源文件报404问题的修复方法(总结篇)
2018/01/09 Javascript
webpack@v4升级踩坑(小结)
2018/10/08 Javascript
vuex根据不同的用户权限展示不同的路由列表功能
2019/09/20 Javascript
使用Vue调取接口,并渲染数据的示例代码
2019/10/28 Javascript
浅析TypeScript 命名空间
2020/03/19 Javascript
JavaScript文档加载模式以及元素获取
2020/07/28 Javascript
jQuery实现滑动开关效果
2020/08/02 jQuery
python变量不能以数字打头详解
2016/07/06 Python
python 实现数组list 添加、修改、删除的方法
2018/04/04 Python
Python基于TCP实现会聊天的小机器人功能示例
2018/04/09 Python
对python字典过滤条件的实例详解
2019/01/22 Python
Django--权限Permissions的例子
2019/08/28 Python
Python字符串格式化输出代码实例
2019/11/22 Python
pandas apply使用多列计算生成新的列实现示例
2021/02/24 Python
数控技术专业推荐信
2013/11/01 职场文书
2014年大学生党课心得体会范文
2014/03/29 职场文书
工商企业管理专业自荐信范文
2014/04/12 职场文书
学习雷锋倡议书
2014/04/15 职场文书
青年岗位能手事迹材料(2016推荐版)
2016/03/01 职场文书
SQL Server基本使用和简单的CRUD操作
2021/04/05 SQL Server
ElementUI实现el-form表单重置功能按钮
2021/07/21 Javascript