本文实例为大家分享了jquery实现简单每周轮换日历的具体代码,供大家参考,具体内容如下
先放出一张示例图
在进入页面时自动获取本地时间并激活(示例为2020年9月8日),再点击左按钮时倒退一周,右按钮前进一周。鼠标点击其中li标签时激活并在上方日期显示。
一个很简单的小日历,主要是项目中经常会使用到就单独拿出来写个demo。具体思路是,获取当前本地日期并推断出周一和周日进而获得本周全部的日期,真正存放的是一个长度为7的时间戳数组,只是显示的是日期,因为我认为利用时间戳做大部分处理比较直接简单。如果有更好思路的小伙伴欢迎批评。下面放出代码。
HTML
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | < div id = "app" > < div class = "title" ></ div > < div class = "left" ><</ div > < ul > < li ></ li > < li ></ li > < li ></ li > < li ></ li > < li ></ li > < li ></ li > < li ></ li > </ ul > < div class = "right" >></ div > </ div > |
CSS
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 | <style> #app { width : 400px ; height : 50px ; margin : 200px auto ; position : relative ; color : darkgray; } .title { position : absolute ; top : -50px ; left : 0 ; width : 200px ; height : 50px ; } ul { list-style : none ; background-color : blanchedalmond; width : 100% ; display : block ; padding : 0 ; } ul li { display : inline- block ; width : 50px ; height : 50px ; text-align : center ; line-height : 50px ; cursor : pointer ; } . left { position : absolute ; top : 0 ; left : -50px ; font-size : 35px ; cursor : pointer ; } . right { position : absolute ; top : 0 ; right : -50px ; font-size : 35px ; cursor : pointer ; } .on { color : darkorange; } </style> |
JS
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 | <script> let now = new Date() let oneDay = 1000*60*60*24 // 一天的时间 let timeArr = [] // 用来存储每次循环真正时间戳的数组 let onDate = now.getTime() // 当前激活的日期(有且仅有一个) init() // 点击后添加激活样式 $( 'ul li' ).on( 'click' , function () { acton($( this ).index()) }) $( '.left' ).on( 'click' , function () { changeUl(0) }) $( '.right' ).on( 'click' , function () { changeUl(1) }) function init() { // 计算初始化时的周一和周天 let monday = now.getTime() - (now.getDay() - 1)*oneDay let sunday = now.getTime() + (7 - now.getDay())*oneDay // 循环渲染本周 for (let i = 0;i < 7;i++) { let nowDate = monday + oneDay * i $( 'ul li' ).eq(i).text( new Date(nowDate).getDate()) timeArr.push(nowDate) if (nowDate === now.getTime()) { // 初始化时渲染标签并激活当前本地日期和显示 acton(i) } } } // 判断数组中是否存在该日期并激活 function judon() { if (timeArr.indexOf(onDate) !== -1) { $( 'ul li' ).eq(timeArr.indexOf(onDate)).addClass( 'on' ).siblings().removeClass( 'on' ) } else { $( 'ul li' ).each( function () { $( this ).removeClass( 'on' ) }) } } // 点击前后实现更换每周内容,1是前进一周,0是后退一周 function changeUl(type) { for (let n = 0;n < 7;n++) { timeArr[n] = type ? timeArr[n] + oneDay*7 : timeArr[n] - oneDay*7 $( 'ul li' ).eq(n).text( new Date(timeArr[n]).getDate()) } judon() } // 激活日期并显示 function acton(i) { let nowTitle = new Date(timeArr[i]); $( 'ul li' ).eq(i).addClass( 'on' ).siblings().removeClass( 'on' ); $( '.title' ).text(`${nowTitle.getFullYear()}年${nowTitle.getMonth()+1}月${nowTitle.getDate()}日`); onDate = timeArr[i] } </script> |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自学编程网。
- 本文固定链接: https://zxbcw.cn/post/195307/
- 转载请注明:必须在正文中标注并保留原文链接
- QQ群: PHP高手阵营官方总群(344148542)
- QQ群: Yii2.0开发(304864863)