当前位置:首页 > 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实现拖拽

实现拖拽的基本步骤 通过监听鼠标事件(mousedown、mousemove、mouseup)实现拖拽功能。以下是核心代码逻辑: const draggableElement = document.…

js实现全选

js实现全选

实现全选功能的方法 在JavaScript中实现全选功能通常涉及监听全选复选框的点击事件,并根据其状态控制其他复选框的选中状态。以下是几种常见的实现方式: 基础DOM操作实现 通过获取所有目标复选框…

js 实现链表

js 实现链表

链表的基本概念 链表是一种线性数据结构,由一系列节点组成,每个节点包含数据和指向下一个节点的指针。与数组不同,链表在内存中是非连续存储的,插入和删除操作效率较高。 链表的实现 在 JavaScrip…

js画图实现

js画图实现

使用Canvas API绘制图形 Canvas是HTML5提供的绘图API,通过JavaScript操作Canvas元素可以绘制各种图形。以下是一个简单的示例: <canvas id="myC…

js实现滚动

js实现滚动

实现滚动效果的方法 在JavaScript中实现滚动效果可以通过多种方式完成,以下是一些常见的方法: 使用window.scrollTo() window.scrollTo()方法可以将页面滚动到指…

js验证码的实现

js验证码的实现

验证码的基本实现原理 验证码(CAPTCHA)的核心目标是区分人类用户和自动化程序。JavaScript可用于生成或验证客户端验证码,但需注意纯前端验证可能被绕过,通常需结合后端验证。 纯前端验证码…