This article shares the specific code of js to achieve a simple calendar effect for your reference. The specific content is as follows ## css module <style type="text/css"> *{ margin: 0; padding: 0; } .date{ width: 300px; height: 220px; border: 1px solid #000; margin: 100px auto; } .title{ width: 200px; display: flex; font-size: 12px; margin: auto; text-align: center; justify-content: space-around; align-items: center; } .year{ margin: 0 40px; display: flex; flex-direction: column; } #week{ border-top: 1px solid #000; border-bottom: 1px solid #000; margin: auto; list-style-type: none; display: flex; } #week li{ display: inline-block; text-align: center; flex:1; } #ul{ list-style-type: none; margin-top: 5px; } #ul li { display: inline-block; width: 40px; height: 21px; text-align: center; border: 1px solid #fff; } .current{ color:red; } #ul li:hover{ border: 1px solid red; } #prev,#next{ cursor: pointer; } </style> ##html <div class="date"> <div class="title"> <span id="prev"><Previous month</span> <div class="year"> <span id="year">2021</span> <span id="month">May</span> </div> <span id="next">Next month></span> </div> <!-- Use ul to make a calendar --> <ul id="week"> <li>Day</li> <li>One</li> <li>Two</li> <li>Three</li> <li>Four</li> <li>Five</li> <li>Six</li> </ul> <ul id="ul"> </ul> </div> ## js code <script type="text/javascript"> // Date object, convenient for switching months, so set it as global let date = new Date(); // Click to switch the month event document.getElementById('prev').addEventListener('click',function(){ date.setMonth(date.getMonth()-1); add(); }) document.getElementById('next').addEventListener('click',function(){ date.setMonth(date.getMonth()+1); add(); }) add(); //Function to create calendar function add(){ // Current year let cYear = date.getFullYear(); // Current month let cMonth = date.getMonth()+1; // Get the current date let cDay = date.getDate(); // Write the year and month document.getElementById('year').innerHTML = cYear; document.getElementById('month').innerHTML = cMonth+'月'; let days = new Date(cYear,cMonth,-1); // The number of days in the current month let n = days.getDate()+1; // What day of the week is the first day of each month let week = new Date(cYear,cMonth-1,1).getDay(); let html = ''; //Write to dom for(let i=0;i<week;i++){ html+=`<li></li>` } for(let i=1;i<=n;i++){ if(i==cDay){ html+=`<li class="current">${i}</li>` }else{ html+=`<li>${i}</li>` } } // Insert once document.getElementById('ul').innerHTML = html } </script> The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM. You may also be interested in:
|
<<: Complete steps for Nginx to configure anti-hotlinking
>>: Solution to forgetting mysql password under linux
With the development of Internet technology, user...
Macrotasks and Microtasks JavaScript is a single-...
Asynchronous replication MySQL replication is asy...
The specific code of JavaScript date effects is f...
Solution process: Method 1: The default kernel ve...
Elasticsearch is very popular now, and many compa...
Alibaba Cloud Server cannot connect to FTP FileZi...
Table of contents 1. Introduction 2. Several ways...
Preface As you all know, we have encountered many...
Table of contents 1. What is Function Anti-shake?...
Table of contents background explore Summarize ba...
The author has been working on a micro-frontend p...
Sometimes, we don't want the content presente...
The Drag and Drop API adds draggable elements to ...
Today I encountered a very strange situation. Aft...