jquery實(shí)現(xiàn)簡單每周輪換的日歷
本文實(shí)例為大家分享了jquery實(shí)現(xiàn)簡單每周輪換日歷的具體代碼,供大家參考,具體內(nèi)容如下
先放出一張示例圖
在進(jìn)入頁面時(shí)自動(dòng)獲取本地時(shí)間并激活(示例為2020年9月8日),再點(diǎn)擊左按鈕時(shí)倒退一周,右按鈕前進(jìn)一周。鼠標(biāo)點(diǎn)擊其中l(wèi)i標(biāo)簽時(shí)激活并在上方日期顯示。
一個(gè)很簡單的小日歷,主要是項(xiàng)目中經(jīng)常會(huì)使用到就單獨(dú)拿出來寫個(gè)demo。具體思路是,獲取當(dāng)前本地日期并推斷出周一和周日進(jìn)而獲得本周全部的日期,真正存放的是一個(gè)長度為7的時(shí)間戳數(shù)組,只是顯示的是日期,因?yàn)槲艺J(rèn)為利用時(shí)間戳做大部分處理比較直接簡單。如果有更好思路的小伙伴歡迎批評(píng)。下面放出代碼。
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 // 一天的時(shí)間 let timeArr = [] // 用來存儲(chǔ)每次循環(huán)真正時(shí)間戳的數(shù)組 let onDate = now.getTime() // 當(dāng)前激活的日期(有且僅有一個(gè)) init() // 點(diǎn)擊后添加激活樣式 $('ul li').on('click', function() { acton($(this).index()) }) $('.left').on('click', function() { changeUl(0) }) $('.right').on('click', function() { changeUl(1) }) function init() { // 計(jì)算初始化時(shí)的周一和周天 let monday = now.getTime() - (now.getDay() - 1)*oneDay let sunday = now.getTime() + (7 - now.getDay())*oneDay // 循環(huán)渲染本周 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()) { // 初始化時(shí)渲染標(biāo)簽并激活當(dāng)前本地日期和顯示 acton(i) } } } // 判斷數(shù)組中是否存在該日期并激活 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') }) } } // 點(diǎn)擊前后實(shí)現(xiàn)更換每周內(nèi)容,1是前進(jìn)一周,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>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 基于jquery實(shí)現(xiàn)日歷簽到功能
- jQuery EasyUI API 中文文檔 - Calendar日歷使用
- 為開發(fā)者準(zhǔn)備的10款最好的jQuery日歷插件
- jQuery簡單實(shí)現(xiàn)日歷的方法
- jQuery寫的日歷(包括日歷的樣式及功能)
- jQuery 聯(lián)動(dòng)日歷實(shí)現(xiàn)代碼
- .net mvc頁面UI之Jquery博客日歷控件實(shí)現(xiàn)代碼
- php+mysql+jquery實(shí)現(xiàn)日歷簽到功能
- JQuery日歷插件My97DatePicker日期范圍限制
- Jquery日歷插件制作簡單日歷
相關(guān)文章
jQuery實(shí)現(xiàn)高亮顯示網(wǎng)頁關(guān)鍵詞的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)高亮顯示網(wǎng)頁關(guān)鍵詞的方法,涉及jquery針對(duì)頁面字符串的遍歷與正則替換的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-08-08jquery選擇器-根據(jù)多個(gè)屬性選擇示例代碼
根據(jù)多個(gè)屬性選擇在某些對(duì)選擇比較精確的情況下,還是比較實(shí)用的,其實(shí)很簡單,不會(huì)的朋友看下本文2013-10-10jQuery實(shí)現(xiàn)表單驗(yàn)證功能
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)表單驗(yàn)證功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10詳解Jquery EasyUI tree 的異步加載(遍歷指定文件夾,根據(jù)文件夾內(nèi)的文件生成tree)
本篇文章主要介紹了Jquery EasyUI tree 的異步加載,可以實(shí)現(xiàn)遍歷指定文件夾,根據(jù)文件夾內(nèi)的文件生成tree,有興趣的可以了解一下。2017-02-02運(yùn)用jQuery寫的驗(yàn)證表單(實(shí)例講解)
下面小編就為大家?guī)硪黄\(yùn)用jQuery寫的驗(yàn)證表單(實(shí)例講解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07jQuery 全選 全部選 反選 實(shí)現(xiàn)代碼
上次做了一個(gè)前端項(xiàng)目,其中有功能要求實(shí)現(xiàn)jquery 全選和反選功能,下面小編抽個(gè)時(shí)間把實(shí)現(xiàn)代碼分享到腳本之家平臺(tái)供大家參考下2016-08-08jquery UI Datepicker時(shí)間控件的使用方法(終結(jié)版)
這篇文章是jquery UI Datepicker時(shí)間控件的使用方法終結(jié)版,可以說是技術(shù)的升華,實(shí)現(xiàn)的功能有限制的開始時(shí)間和結(jié)束時(shí)間跨度不超過三天,并配置有清空時(shí)間,重選時(shí)間等,感興趣的小伙伴們可以參考一下2015-11-11jQuery實(shí)現(xiàn)移動(dòng)端滑塊拖動(dòng)選擇數(shù)字效果
這篇文章主要介紹了jQuery實(shí)現(xiàn)移動(dòng)端滑塊拖動(dòng)選擇數(shù)字效果,jQuery實(shí)現(xiàn)移動(dòng)端滑塊拖動(dòng)效果,感興趣的小伙伴們可以參考一下2015-12-12EasyUI Combobox設(shè)置默認(rèn)值 獲取text的方法
這篇文章主要介紹了EasyUI Combobox設(shè)置默認(rèn)值 獲取text的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11