你的生日是星期几?HTML+JavaScript帮你列出来

0 源起


上周末,大宝发现今年自己的生日不是周末,这样就不好约同学和好友一起开生日Party了,很是郁闷。一直嘀咕自己哪年的生日才是周末。
于是我用JavaScript写了一个小程序来帮她测算了未来100年中每年的生日分别是星期几。

1 设计交互界面


用一个文本框来输入年份,
一个下拉列表框来选择月份,
一个下拉列表框来选择日,
一个按钮来进行测算,
一个多行文本输入框来显示测算结果。

<p>你的生日是星期几?</p>
<p>请输入生日信息</p>
<input type="text" id="txtYear" value="2024">年<select id="lsbMonth"></select>月<select id="lsbDay"></select>日
<input type="button" value="测算" id="btnCheck">
<p><textarea id="taResult" rows="15" cols="60"></textarea></p>

主打简洁,如下图:

2 输入控制

2.1 年份文本框只允输入4位整数

 当用户修改年份文本框中的内容,导致文本框的值发生改变时,会触发oninput事件,我们对这个事件进行处置,只允许输入数字,并且只保留前4位数字。

//年份输入处理
function txtYear_onInput()
{var a = txtYear.value.replace(/[^\d]/g,'');//只允许输入数字txtYear.value = a.substr(0,4);//只允许四位数字
} // txtYear_onInput()txtYear.oninput = function() {txtYear_onInput()};

2.2 月份列表框

一年12个月,用一个函数来填充其值。

//初始化月份
function lsbMonth_Init()
{for (var i=1;i<13; i++){lsbMonth.options[i-1] = new Option(i, i, true, true);    }lsbMonth.selectedIndex = 0;
}//lsbMonth_Init();lsbMonth_Init();

2.3 日列表框

每年的1月、3月、5月、7月、8月、10月、12月是31天。

每年的14月、6月、9月、11月是30天。

2月特殊一些,平年是28天,闰年是29天。

我们先初始化日列表框为31天。

//初始化“日”下拉列表框
function lsbDay_Init()
{for (var i = 0;i < 31; i++){lsbDay.options[i] = new Option(i+1,i+1,true,true);}lsbDay.selectedIndex = 0;
}//lsbDay_Init();lsbDay_Init();

当用户修改年份时,会触发onchange事件,

当用户修改月份时,也会触发onchange事件,

我们对这两个事件进行处理:

  1. 先获取年份和月份的值,
  2. 如果用户选择的是2月,就判断用户选择的年份是平年还是闰年,平年就是28天,闰年就29天。
  3. 如果用户选择的是1月、3月、5月、7月、8月、10月或12月,那么就是31天,否则就是30天。
  4. 根据测算出来的天数调整日列表框的值。
//获取年份
function txtYear_getYear()
{return txtYear.value;//return document.getElementById("txtYear").value;
}
//alert(txtYear_getYear())//获取月份
function lsbMonth_getMonth()
{return lsbMonth.options[lsbMonth.selectedIndex].value;
}//判断是否为闰年
function isLeapYear(y)
{return (y % 4 == 0 && y % 100 !=0 || y % 400 == 0);
}//根据用户输入的年份和月份,动态调整“日”下拉列表框的内容
function lsbDay_Adjust()
{var s = lsbDay.selectedIndex;//alert('typeof s='+ typeof(s)+ ' s='+s);var y = txtYear_getYear();//alert('y='+y);if (y <= 0){alert("请先输入年份");return;}var m = lsbMonth_getMonth();//alert('m='+ m);var d;if (2==m){d = isLeapYear(y) ? 29 : 28;}else{d = (m==1 || m==3 || m==5 | m==7 || m==8 || m==10 || m==12 ? 31 : 30); }//alert('d='+d);lsbDay.options.length = d;//alert('lsbDay.options.length='+lsbDay.options.length);for (var i = 0;i < d; i++){lsbDay.options[i] = new Option(i+1,i+1,true,true);}lsbDay.selectedIndex = s < d ? s : 0;
}//lsbDay_Adjust();txtYear.oninput = function() {txtYear_onInput()};txtYear.onchange = function() {lsbDay_Adjust()};

2.4 测算按钮

获取年月日数值,使用日期对象的getFullYear() 方法生成一个日期,然用利用日期对象的getDay() 方法返回指定日期是星期几,把结果填入测算结果。

btnCheck.onclick = function(){checkDay()};function lsbDay_getDay()
{return lsbDay.options[lsbDay.selectedIndex].value;
}function checkDay()
{var a = new Date();var y = txtYear_getYear(), m = lsbMonth_getMonth(), d = lsbDay_getDay();var w, s, r = '';for (var i=0;i < 100;i++){a.setFullYear(y*1+i ,m-1,d);w = a.getDay();s = '';//alert(a);r += a.getFullYear() + '年' + m + '月' + d + '日 是 星期' + "日一二三四五六".charAt(w) + '\n';}  //fortaResult.value = r;
}

3 一些改进思路

1.初始化年月日时将默认值 设置系统当前日期

2.可以使用 date输入框:

 <input type="date" value="2024-06-01">

3.使用<iframe>代替<textarea>,对周日——周六分别用不同的颜色来显示。

 

4.用户界面上可以加上一个生日蛋糕之类的图片烘托氛围。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/36100.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

torch创建2d卷积层报错

import torch import torch.nn as nn print(nn.Conv2d(3, 16, 3, padding1)) 编译器:pycharm2023.03.05 python&#xff1a;3.11 运行上述代码 页面报错&#xff1a;OSError: [WinError 126] 找不到指定的模块。 Error loading "D:\apploadpath\pythonPath\Lib\site-…

logback自定义规则脱敏

自定义规则conversionRule public class LogabckMessageConverter extends MessageConverter {Overridepublic String convert(ILoggingEvent event) {String msg event.getMessage();if ("INFO".equals(event.getLevel().toString())) {msg .....脱敏实现}return …

搭建大型分布式服务(四十一)SpringBoot 整合多个kafka数据源-支持亿级消息生产者

系列文章目录 文章目录 系列文章目录前言一、本文要点二、开发环境三、原项目四、修改项目五、测试一下五、小结 前言 本插件稳定运行上百个kafka项目&#xff0c;每天处理上亿级的数据的精简小插件&#xff0c;快速上手。 <dependency><groupId>io.github.vipjo…

【ARM】MCU和SOC的区别

【更多软件使用问题请点击亿道电子官方网站】 1、 文档目标 了解SOC芯片和MCU芯片的区别 2、 问题场景 用于了解SOC芯片和MCU芯片的区别&#xff0c;内部结构上的区别。 3、软硬件环境 1&#xff09;、软件版本&#xff1a;无 2&#xff09;、电脑环境&#xff1a;无 3&am…

【小学期】安装Navicat,可视化操作数据库

什么是Navicat&#xff0c;如何安装&#xff1f;如何操作&#xff1f; 1. 什么是Navicat&#xff1f; Navicat 是一款功能强大的数据库管理工具&#xff0c;支持多种数据库系统&#xff0c;包括 MySQL、PostgreSQL、SQLite、Oracle、MariaDB 和 SQL Server 等。Navicat 提供了…

Java——枚举

1. 概念 枚举是在JDK1.5之后引入的&#xff0c;主要用途是&#xff1a;将一组常量组织起来&#xff0c;在这之前表示一组常量通常使用定义常量的方式&#xff1a; public static final int RED 1; public static final int GREEN 2; public static final int BLACK 3;但是…

意识与通用人工智能:北京智源大会深度解读

在科技迅猛发展的今天&#xff0c;人工智能&#xff08;AI&#xff09;的意识问题成为了学术界和公众关注的焦点。北京智源大会汇聚了众多学者&#xff0c;围绕意识与通用人工智能&#xff08;AGI&#xff09;的关系进行了深入探讨。本文将对大会的精彩观点进行总结&#xff0c…

clickhouse join内存溢出

clickhouse join 内存溢出 前言排查步骤查看sql统计数据量统计大小优化索引优化字段增加内存最终优化 前言 在一个离线工作流中任务报错 Code: 241. DB::Exception: Received from XXXXXX:9000. DB::Exception: Memory limit (for query) exceeded: would use 20.49 GiB (att…

第 12 课:基于隐语的VisionTransformer框架

基于之前MPC的基础知识&#xff0c;本讲主要内容是MPCViT基于SecretFlow的VisionTransformer框架&#xff0c;主要从神经网络架构&#xff0c;隐私推理框架和实验结果三方面介绍。 一、MPCViT&#xff1a;安全且高效的MPC友好型 Vision Transformer架构 MPCViT隐私推理总体框架…

QT中子工程的创建,以及如何在含有库的子工程项目中引用主项目中的qt资源

1、背景 在qt中创建多项目类型,如下: CustomDll表示其中的一个动态库子项目; CustomLib表示其中的一个静态库子项目; MyWidget表示主项目窗口(main函数所在项目); 2、qrc资源的共享 如何在CustomDll和CustomLib等子项目中也同样使用 MyWidget项目中的qrc资源呢??? 直…

【AI应用探讨】—决策树应用场景

目录 1 命名实体识别&#xff08;NER&#xff09; 2 信用评估 3 医学诊断 4 垃圾邮件过滤 5 推荐系统 6 金融欺诈检测 7 医疗领域的其他应用 8 网络行为管理系统 1 命名实体识别&#xff08;NER&#xff09; 应用场景&#xff1a;在文本处理中&#xff0c;决策树可以用…

【项目实训】后端逻辑完善

经测试&#xff0c;我们决定前端可以同时选择多个类型的岗位进行查询&#xff0c;以显示相应的公司岗位信息 于是&#xff0c;修改后端函数的逻辑&#xff1a; 后端 首先&#xff0c;因为要对checkList中的job_name进行模糊匹配查询&#xff0c;于是使用以下代码&#xff1a…

mybatis批量处理

批量修改 <update id"updateTaskDistributions" parameterType"java.util.List"><foreach collection"viewTaskDistributions" index"index" item"item" open"begin" close";end;" separa…

【科学计算与可视化】3. Matplotlib 绘图基础

安装 pip install matplotlib 官方文档 https://matplotlib.org/stable/api/pyplot_summary.html 主要介绍一些图片绘制的简要使用&#xff0c;更加详细和进阶需要可参考 以上官方文档。 1 绘制基础 方法名说明title()设置图表的名称xlabel()设置 x 轴名称ylabel()设置 y 轴…

双指针:比较含退格的字符串

题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 代码看起来繁琐&#xff0c;但实际思想并不难。核心思路是&#xff1a;倒序遍历&#xff0c;遇到#就记录跳过次数&#xff0c;遇到字母就跳过记录次数&#xff0c;最后比较不用跳过时的字母是否一样。 class S…

负载组指南说明-负载柜

什么是负载组&#xff1f; 负载组是一种设备&#xff0c;旨在准确模拟电源在实际应用中看到的负载。这种负载组可以用电阻、电感或电容元件构建。它是一种电阻装置&#xff0c;以热量的形式消散一定量的能量&#xff0c;可以通过自然对流、强制空气或水冷系统去除。 为什么要使…

江协科技51单片机学习- p11 Proteus安装模拟51单片机

前言&#xff1a; 本文是根据哔哩哔哩网站上“江协科技51单片机”视频的学习笔记&#xff0c;在这里会记录下江协科技51单片机开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了江协科技51单片机教学视频和链接中的内容。 引用&#xff1a; Proteus快速入门&…

可溶性聚四氟乙烯离子交换柱PFA层析柱微柱一体成型

PFA微柱&#xff0c;也叫PFA层析柱、PFA离子交换柱等&#xff0c;主要用于地质同位素超净化、痕量、超痕量、微量元素分析实验室。 规格参考&#xff1a;1.5ml、15ml、30ml等。 其主要特性有&#xff1a; 1、PFA层析柱&#xff08;微柱&#xff09;专为离子交换设计&#xff…

SAP ERP公有云(全称 SAP S/4HANA Cloud Public Edition),赋能企业成为智能可持续的企业

在数字化浪潮中&#xff0c;每一家企业都需要应对快速的市场变化&#xff0c;不断追求降本增效&#xff0c;为创新提供资源&#xff0c;发展新的业务模式&#xff0c;安全无忧地完成关键任务系统的转型。 10年前&#xff0c;SAP进入云领域&#xff0c;用云ERP和覆盖全线业务的云…

双通道源表KEITHELY2636B详情参数吉时利2636B

Keithley的2636B是一款2600B系列双通道系统源表(SMU)仪器(0.1fA, 10A脉冲)。它是业界领先的电流/电压源和测量解决方案。这种双通道模型结合了精密电源&#xff0c;真电流源&#xff0c;6 1/2位DMM&#xff0c;任意波形发生器&#xff0c;脉冲发生器和电子负载的能力&#xff0…