js to achieve simple calendar effect

js to achieve simple calendar effect

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">&lt;Previous month</span>
   <div class="year">
    <span id="year">2021</span>
    <span id="month">May</span>
   </div>
   <span id="next">Next month&gt;</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:
  • js css+html to realize a simple calendar
  • A guide to using calendar.js, a lightweight native js calendar plugin
  • JS learning a simple calendar control
  • Vue.js creates Calendar effect
  • JS Calendar Recommendation
  • Pure js simple calendar implementation code
  • js writes a simple calendar effect for the day [implementation code]
  • js calendar control (accurate to the minute)
  • PHP+javascript calendar control
  • Simple JS calendar control example code

<<:  Complete steps for Nginx to configure anti-hotlinking

>>:  Solution to forgetting mysql password under linux

Recommend

Web front-end development course What are the web front-end development tools

With the development of Internet technology, user...

JavaScript macrotasks and microtasks

Macrotasks and Microtasks JavaScript is a single-...

Summary of several replication methods for MySQL master-slave replication

Asynchronous replication MySQL replication is asy...

JavaScript implements simple date effects

The specific code of JavaScript date effects is f...

How to install elasticsearch and kibana in docker

Elasticsearch is very popular now, and many compa...

Solution for FileZilla 425 Unable to connect to FTP (Alibaba Cloud Server)

Alibaba Cloud Server cannot connect to FTP FileZi...

Several ways to clear arrays in Vue (summary)

Table of contents 1. Introduction 2. Several ways...

Implementation and usage scenarios of JS anti-shake throttling function

Table of contents 1. What is Function Anti-shake?...

A summary of the reasons why Mysql does not use date field index

Table of contents background explore Summarize ba...

Use scripts to package and upload Docker images with one click

The author has been working on a micro-frontend p...

How to use HTML 5 drag and drop API in Vue

The Drag and Drop API adds draggable elements to ...

Solution to Docker's failure to release ports

Today I encountered a very strange situation. Aft...