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++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

vue, 左右布局宽,可拖动改变

1:建立一个draggableMixin.js  混入的方式使用 2:代码如下draggableMixin.js  export default {data() {return {leftWidth: 330,isDragging: false,startX: 0,startWidth: 0,};},methods: {startDragging(e) {this.isDragging = tr

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

js+css二级导航

效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Con

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页:

探索蓝牙协议的奥秘:用ESP32实现高质量蓝牙音频传输

蓝牙(Bluetooth)是一种短距离无线通信技术,广泛应用于各种电子设备之间的数据传输。自1994年由爱立信公司首次提出以来,蓝牙技术已经经历了多个版本的更新和改进。本文将详细介绍蓝牙协议,并通过一个具体的项目——使用ESP32实现蓝牙音频传输,来展示蓝牙协议的实际应用及其优点。 蓝牙协议概述 蓝牙协议栈 蓝牙协议栈是蓝牙技术的核心,定义了蓝牙设备之间如何进行通信。蓝牙协议

vue+elementUI下拉框联动显示

<el-row><el-col :span="12"><el-form-item label="主账号:" prop="partyAccountId" :rules="[ { required: true, message: '主账号不能为空'}]"><el-select v-model="detailForm.partyAccountId" filterable placeholder="