js实现,改变两个《select》年月下拉框的值,得到当年当月的日历

2024-02-07 13:08

本文主要是介绍js实现,改变两个《select》年月下拉框的值,得到当年当月的日历,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 效果图:改变两个《select》下拉框的值,得到当年当月的日历

思路 :

 <!---改变两个《select》下拉框的值,得到当年当月的日历

    具体思路:

    1。添加下拉框的值

    2。下拉框值的changen函数

    3。输出日历的方法:

        1.得到这个月的一月一日是星期几,getday()

        2.得到这个月有多少天,getDate();

        2.输出这个月的每一天-->

代码 :

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>日历</title><style>*{margin: 0px;padding: 0px;font-family:'Courier New', Courier, monospace;}#wrap{width: 700px;height: auto;margin: 50px auto;}.head{width: 100%;height: 60px;line-height: 60px;background: #666;text-align: center;color: #fff;}ul{width: 100%;}#title{width: 100%;height: 60px;line-height: 60px;text-align: center;display: flex;justify-content: space-between;}li{list-style-type: none;text-align: center;width: 100px;}#dateul li{list-style: none;text-align: center;width: 98px;float: left;height: 60px;line-height: 60px;border: 1px solid red;}</style>
</head>
<body><!---改变两个《select》下拉框的值,得到当年当月的日历具体思路:1。添加下拉框的值2。下拉框值的changen函数3。输出日历的方法:1.得到这个月的一月一日是星期几,getday()2.输出这个月的每一天--><div id="wrap"><div class="head"><select id="year"></select>年<select id="month"></select>月</div><ul id="title"><li>星期日</li><li>星期一</li><li>星期二</li><li>星期三</li><li>星期四</li><li>星期五</li><li>星期六</li></ul><ul id="dateul"></ul></div><script>//初始化select内容var year=document.getElementById("year");var month=document.getElementById("month");var dateul=document.getElementById("dateul");for (var y = 1990;y <3000;y++) {year.add(new Option(y,y));}for (var m = 0; m <12; m++) {month.add(new Option(m+1,m));//0代表1月}//初始化输入今天的日历onload=function(){var now=new Date();year.value=now.getFullYear();month.value=now.getMonth();showdate()}//onchang事件year.onchange=function(){showdate();}month.onchange=function(){showdate();}//输入日历function showdate(){dateul.innerHTML="";//清空var da=new Date(year.value,month.value);//获取当前下拉框的日期for(var i=0;i<da.getDay();i++)//得到这个月的一月一日是星期几{createLi("",dateul);}var TheMonthDayNumber=mGetDay(year.value,month.value);for (var i = 1; i <=TheMonthDayNumber; i++) {createLi(i,dateul);}}//返回年月中月的天数function mGetDay(yearNumber,monthNumber){monthNumber++;var thisDate =new Date(yearNumber,monthNumber,0)//后一个月的0天,表示前一个月的最后一天,即d为month月的天数return thisDate .getDate();}//输出li的函数,//给box盒子添加一个子元素 lifunction createLi(text,box){var li=document.createElement("li");li.innerHTML=text;box.appendChild(li);}</script>
</body>
</html>

 

注意事项: 

月份的范围是(0-11),

获取一个月的天数:

getDate() 可以取得当前月份的日期,如果要获取2020年六月的日期,可以实例化 new Date(2020,6,0),【月份从0开始这里的6是六月份】,因为6月0日是一个错误的日期格式,js自动纠错,所以实际日期变成了2020年5月的最后一天,所以getDate()获取的就是5月最后一天的日期【月份从0开始这里的5是六月份】。

这篇关于js实现,改变两个《select》年月下拉框的值,得到当年当月的日历的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/687822

相关文章

如何使用C#串口通讯实现数据的发送和接收

《如何使用C#串口通讯实现数据的发送和接收》本文详细介绍了如何使用C#实现基于串口通讯的数据发送和接收,通过SerialPort类,我们可以轻松实现串口通讯,并结合事件机制实现数据的传递和处理,感兴趣... 目录1. 概述2. 关键技术点2.1 SerialPort类2.2 异步接收数据2.3 数据解析2.

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu

Qt把文件夹从A移动到B的实现示例

《Qt把文件夹从A移动到B的实现示例》本文主要介绍了Qt把文件夹从A移动到B的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录如何移动一个文件? 如何移动文件夹(包含里面的全部内容):如何删除文件夹:QT 文件复制,移动(

Flask 验证码自动生成的实现示例

《Flask验证码自动生成的实现示例》本文主要介绍了Flask验证码自动生成的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 目录生成图片以及结果处理验证码蓝图html页面展示想必验证码大家都有所了解,但是可以自己定义图片验证码

VSCode配置Anaconda Python环境的实现

《VSCode配置AnacondaPython环境的实现》VisualStudioCode中可以使用Anaconda环境进行Python开发,本文主要介绍了VSCode配置AnacondaPytho... 目录前言一、安装 Visual Studio Code 和 Anaconda二、创建或激活 conda

使用mvn deploy命令上传jar包的实现

《使用mvndeploy命令上传jar包的实现》本文介绍了使用mvndeploy:deploy-file命令将本地仓库中的JAR包重新发布到Maven私服,文中通过示例代码介绍的非常详细,对大家的学... 目录一、背景二、环境三、配置nexus上传账号四、执行deploy命令上传包1. 首先需要把本地仓中要

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固 通俗易懂版)

《MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固通俗易懂版)》本文主要讲解了MySQL中的多表查询,包括子查询、笛卡尔积、自连接、多表查询的实现方法以及多列子查询等,通过实际例子和操... 目录复合查询1. 回顾查询基本操作group by 分组having1. 显示部门号为10的部门名,员

java导出pdf文件的详细实现方法

《java导出pdf文件的详细实现方法》:本文主要介绍java导出pdf文件的详细实现方法,包括制作模板、获取中文字体文件、实现后端服务以及前端发起请求并生成下载链接,需要的朋友可以参考下... 目录使用注意点包含内容1、制作pdf模板2、获取pdf导出中文需要的文件3、实现4、前端发起请求并生成下载链接使

Java的volatile和sychronized底层实现原理解析

《Java的volatile和sychronized底层实现原理解析》文章详细介绍了Java中的synchronized和volatile关键字的底层实现原理,包括字节码层面、JVM层面的实现细节,以... 目录1. 概览2. Synchronized2.1 字节码层面2.2 JVM层面2.2.1 ente