javascript实战——万年历查询

2024-02-26 04:50

本文主要是介绍javascript实战——万年历查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

javascript实战——万年历查询

思路:

1:动态添加年,月;

2:封装遍历方法;

3:添加日:判断平年还是闰年;每个月的第一天是星期几;

html:

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><title>万年历</title><link rel="stylesheet" type="text/css" href="demo.css"><script type="text/javascript" src="index.js"></script>
</head>
<body>
<div id="box"><div id="top"><select id="year"><option value="" class="info_year">请选择年份</option></select>年<select id="month"><option value="" class="info_month">请选择月份</option></select>月<input id='button' type="button" name="button" style="width: 60px;" value="查询"></div><div id="con"><ul class="week"><li>一</li><li>二</li><li>三</li><li>四</li><li>五</li><li>六</li><li>日</li></ul><ul class="day"><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li></ul></div>
</div>
</body>
</html>

css:

*{margin: 0;padding: 0;list-style-type: none;
}
#box{width: 450px;height: 380px;border:1px solid #3399ff;margin:100px auto 0;border-radius: 5px;
}
#top{width: 100%;height: 50px;border-bottom: 1px solid #3399ff;font-size: 15px;
}
#year{margin: 15px 10px;}
#year,#month{text-align: center;margin-right: 15px;}
#con{width: 420px;height: 300px;margin:0 auto 0;}
#con ul.week{width: 420px;height: 45px;
}
#con ul.week li{width: 60px;height: 45px;text-align: center;float: left;}
/*#con ul.week li.weekend{color: red;
}*/
#con ul.day li{width: 60px;height: 45px;border-top: 1px solid #ddd;float: left;line-height: 50px;text-align: center;font-size: 20px;
}

动态添加年月:

js:

window.onload = function(){var listYear = document.getElementById('year');  var listMonth = document.getElementById('month');forEach(function(i){var year = document.createElement('option');year.innerHTML = i;year.value = i;listYear.appendChild(year)},2051,1900)forEach(function(i){var month = document.createElement('option');month.innerHTML = i;month.value = i;listMonth.appendChild(month);},13,1)
}
// 封装遍历方法
function forEach(callback,length,firstNum){var i;i=firstNum?firstNum:0for(;i<length;i++){callback(i)}
}

图示:

第二步:

添加日期:模仿年月;在li标签里添加数字
问题:添加的天数根据每月多少天来写;从哪里添加根据每月的第一天是星期几;

思路:

1:获取所有日期下的li标签;

2:给所有li标签添加内容,需要遍历;

3:在便利条件下,根据年月来确定每月日期,var year = listYear.value;   var month = listMonth.value-1;

4 :每月天数用数组存储,[31,28,31,30,31,30,31,31,30,31,30,31],在遍历之前,闰年:m_day[1]=29;

便利范围<每月天数m_day[month],从0开始遍历,但不从0开始还添加内容;

5:从第几个li开始设置,设置值是多少?
获取所有li标签集合listDay;

获取当月的第一天是星期几firstDay;

添加内容:listDay[i+fisrtDay-1].innerHTML=i+1;当firstDay是0时 listDay[i+firstDay+6].innerHTML=i+1;

6:清理bug:在查询时清理掉所有li标签的内容:forEach(function(i){listDay[i].innerHTML = '';},listDay.length)



这篇关于javascript实战——万年历查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语