本文实例为大家分享了jquery实现简单每周轮换日历的具体代码,供大家参考,具体内容如下
先放出一张示例图
在进入页面时自动获取本地时间并激活(示例为2020年9月8日),再点击左按钮时倒退一周,右按钮前进一周。鼠标点击其中li标签时激活并在上方日期显示。
一个很简单的小日历,主要是项目中经常会使用到就单独拿出来写个demo。具体思路是,获取当前本地日期并推断出周一和周日进而获得本周全部的日期,真正存放的是一个长度为7的时间戳数组,只是显示的是日期,因为我认为利用时间戳做大部分处理比较直接简单。如果有更好思路的小伙伴欢迎批评。下面放出代码。
HTML
<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
<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
<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script> <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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍简单实现jQuery轮播效果,包括了简单实现jQuery轮播效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了jQuery轮播效果展示的具体代码,供大家参考,具体内容如下 jQ代码: 在写jQuery代码之前一定要先导库,此处我用的是3.0的库 css样式: html样式: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍jQuery实现一个简单的轮播图,包括了jQuery实现一个简单的轮播图的使用技巧和注意事项,需要的朋友参考一下 html代码: css代码: js代码: 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持呐喊教程!
本文向大家介绍jQuery简单实现日历的方法,包括了jQuery简单实现日历的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jQuery简单实现日历的方法。分享给大家供大家参考。具体分析如下: 原理挺简单的,首先算出一个月有多少天,再算出这个月的第一天是星期几,接着顺序排下来就可以了. 希望本文所述对大家的jQuery程序设计有所帮助。
本文向大家介绍Jquery实现的简单轮播效果【附实例】,包括了Jquery实现的简单轮播效果【附实例】的使用技巧和注意事项,需要的朋友参考一下 Jquery实现的简单轮播效果【附实例】 以上这篇Jquery实现的简单轮播效果【附实例】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
本文向大家介绍JQUERY简单按钮轮换选中效果实现方法,包括了JQUERY简单按钮轮换选中效果实现方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JQUERY简单按钮轮换选中效果实现方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的jQuery程序设计有所帮助。
本文向大家介绍Jquery实现简单的轮播效果(代码管用),包括了Jquery实现简单的轮播效果(代码管用)的使用技巧和注意事项,需要的朋友参考一下 废话不多说了,直接给大家贴jquery代码了,具体代码如下所示: 以上所述是小编给大家介绍的Jquery实现简单的轮播效果,希望对大家有所帮助!
本文向大家介绍轮播的简单实现方法,包括了轮播的简单实现方法的使用技巧和注意事项,需要的朋友参考一下 1.闪现方式的轮播 不论述,实现比较简单,效果也比较好 2.滑动轮播 以下面的html代码为例(向左滑动) 插件源码:实现向左和向上轮播,手动切换也是向左和向上切换(手动切换关键源码) 滑动轮播的实现方式主要有两种 1)切换父元素margin-left,将第一个子元素不断添加到父容器结尾 简单实现
本文向大家介绍简单实现android轮播图,包括了简单实现android轮播图的使用技巧和注意事项,需要的朋友参考一下 轮播图是很常用的一个效果 核心功能已经实现 没有什么特殊需求 自己没事研究的 所以封装的不太好 一些地方还比较糙 为想要研究轮播图的同学提供个参考 目前测试图片为mipmap中的图片 没有写从网络加载图片 可自行根据需求在getShowView()方法中修改 1.定时切换 通过h