当前位置:首页 > JavaScript

用js实现六十甲子

2026-01-31 07:04:39JavaScript

六十甲子是中国传统历法中的干支纪年系统,由天干(10个)与地支(12个)循环组合而成,共60种组合。以下是使用JavaScript生成六十甲子的实现方法:

定义天干和地支数组

天干和地支需要预先定义,并按顺序组合:

用js实现六十甲子

const heavenlyStems = ['甲', '乙', '丙', '丁', '戊', '己', '庚', '辛', '壬', '癸'];
const earthlyBranches = ['子', '丑', '寅', '卯', '辰', '巳', '午', '未', '申', '酉', '戌', '亥'];

生成六十甲子列表

通过循环将天干与地支按顺序配对,注意天干和地支的循环周期不同(10和12的最小公倍数为60):

用js实现六十甲子

function generateSexagenaryCycle() {
    const cycle = [];
    for (let i = 0; i < 60; i++) {
        const stemIndex = i % heavenlyStems.length;
        const branchIndex = i % earthlyBranches.length;
        cycle.push(heavenlyStems[stemIndex] + earthlyBranches[branchIndex]);
    }
    return cycle;
}

const sexagenaryCycle = generateSexagenaryCycle();
console.log(sexagenaryCycle); // 输出完整的六十甲子数组

根据年份或索引获取对应干支

若需根据特定年份或索引获取干支组合(如2023年为癸卯年),可扩展功能:

function getStemBranchByYear(year) {
    // 已知2020年为庚子年(索引36,因六十甲子循环从0开始)
    const baseYear = 2020;
    const baseIndex = 36;
    const offset = (year - baseYear) % 60;
    const index = (baseIndex + offset + 60) % 60; // 处理负数
    return sexagenaryCycle[index];
}

console.log(getStemBranchByYear(2023)); // 输出 "癸卯"

处理负年份或超出范围的情况

若需支持农历或历史年份,需确保索引计算正确:

function normalizeIndex(index) {
    return ((index % 60) + 60) % 60; // 保证结果在0-59之间
}

输出示例

运行上述代码后,生成的六十甲子列表前5项为:
['甲子', '乙丑', '丙寅', '丁卯', '戊辰', ...]
通过调用getStemBranchByYear(2023)可得到当前年份的干支组合“癸卯”。

标签: 甲子js
分享给朋友:

相关文章

js实现全屏

js实现全屏

实现全屏的基本方法 使用JavaScript实现全屏功能主要依赖Element.requestFullscreen()方法。现代浏览器均支持此API,但不同浏览器可能需要添加前缀。 // 触发全屏…

js实现抽奖

js实现抽奖

实现抽奖功能的基本思路 抽奖功能的核心是随机选择奖项并展示结果。可以通过数组存储奖项,利用随机数生成索引,最后通过动画增强用户体验。 准备奖项数据 定义一个数组存储奖项信息,每个奖项可以包含名称、图…

js实现自举

js实现自举

实现 JavaScript 自举的方法 JavaScript 自举(Bootstrap)通常指通过 JavaScript 动态加载自身或依赖的脚本,实现运行时环境的初始化或扩展。以下是几种常见实现方式…

js怎么实现异步

js怎么实现异步

异步实现方法 JavaScript中实现异步操作主要通过以下几种方式: Promise Promise是ES6引入的异步解决方案,用于处理异步操作的成功或失败状态。 const promise =…

js实现图片

js实现图片

图片加载与显示 在JavaScript中,可以通过Image对象动态加载图片。创建实例后设置src属性触发加载,通过onload回调处理加载完成后的操作: const img = new Ima…

js进度条实现

js进度条实现

使用HTML和CSS创建基础结构 在HTML中创建一个容器元素用于显示进度条,通常使用<div>元素。CSS用于设置进度条的样式,包括宽度、高度、颜色和圆角等属性。 <div cl…