0

0

计算两个 Bootstrap 日期选择器之间年份差的正确方法

聖光之護

聖光之護

发布时间:2026-02-12 17:55:51

|

162人浏览过

|

来源于php中文网

原创

计算两个 Bootstrap 日期选择器之间年份差的正确方法

本文详解如何基于 bootstrap datepicker 获取两个日期间的完整年份差(仅取年份部分相减),避免因日期格式解析错误或方法误用导致结果偏差,并提供可直接运行的完整示例代码与关键注意事项。

在使用 Bootstrap Datepicker 构建日期范围选择功能时,一个常见需求是:根据用户选择的“起始日期”和“结束日期”,快速计算并展示二者之间的整年差值(如 2023–2027 → 4 年)。注意:此处强调的是「年份数值之差」(getFullYear() 直接相减),而非精确到天的完整年龄/间隔计算(如需精确间隔,请用 moment.js 或原生 Date.getTime() 差值换算)。本文聚焦于轻量、准确、可靠的年份差提取方案。

✅ 正确实现逻辑

核心在于两点:

Inworld.ai
Inworld.ai

InWorldAI是一个AI角色开发平台,开发者可以创建具有自然语言、上下文意识和多模态的AI角色,并可以继承到游戏和实时媒体中

下载
  • 安全解析日期字符串:Bootstrap Datepicker 默认输出格式为 "dd/mm/yyyy"(如 "02/05/2023"),而 new Date("02/05/2023") 在部分浏览器中可能被误解析为 "mm/dd/yyyy"。因此,必须先将字符串手动转换为标准格式(yyyy, mm-1, dd)再构造 Date 对象,或确保输入格式被 Date 构造函数稳定识别。
  • 仅提取年份并相减:调用 date.getFullYear() 获取整数年份(如 2027),再执行减法运算。该方式简洁、高效,且完全符合“显示合同年限”等业务场景对“整年跨度”的语义要求。

以下为优化后的完整实现(已修复原文中 parseInt(fdate) 等错误逻辑):

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <title>Bootstrap Datepicker 年份差计算</title>
  <!-- Font Awesome -->
  <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
  <!-- Bootstrap 4 CSS -->
  <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css">
  <!-- Bootstrap Datepicker CSS -->
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-datepicker/1.9.0/css/bootstrap-datepicker3.min.css">
</head>
<body>
  <div class="container mt-4">
    <h5>年份差计算器(基于 Bootstrap Datepicker)</h5>
    <form>
      <div class="form-group mb-3">
        <label>起始日期</label>
        <div class="input-group date datepicker">
          <input type="text" class="form-control" id="fecha1" placeholder="请选择起始日期">
          <div class="input-group-append">
            <span class="input-group-text"><i class="fa fa-calendar"></i></span>
          </div>
        </div>
      </div>

      <div class="form-group mb-3">
        <label>结束日期</label>
        <div class="input-group date datepicker">
          <input type="text" class="form-control" id="fecha2" placeholder="请选择结束日期" onchange="calculateYears()">
          <div class="input-group-append">
            <span class="input-group-text"><i class="fa fa-calendar"></i></span>
          </div>
        </div>
      </div>

      <div class="alert alert-info">
        <strong>年份差:</strong><span id="result">—</span> 年
      </div>
    </form>
  </div>

  <!-- JS Dependencies -->
  <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js"></script>
  <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-datepicker/1.9.0/js/bootstrap-datepicker.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-datepicker/1.9.0/locales/bootstrap-datepicker.zh-CN.min.js"></script>

  <script>
    // 初始化中文日期选择器
    $(function() {
      $('.datepicker').datepicker({
        language: 'zh-CN',
        autoclose: true,
        format: 'dd/mm/yyyy',
        todayHighlight: true
      });
    });

    // 计算年份差
    function calculateYears() {
      const input1 = $('#fecha1').val().trim();
      const input2 = $('#fecha2').val().trim();

      // 校验必填
      if (!input1 || !input2) {
        $('#result').text('—');
        return;
      }

      // 安全解析:将 "dd/mm/yyyy" 转为 Date 对象
      const parseDate = (str) => {
        const parts = str.split('/');
        if (parts.length !== 3) return null;
        const day = parseInt(parts[0], 10);
        const month = parseInt(parts[1], 10) - 1; // 月份从0开始
        const year = parseInt(parts[2], 10);
        return new Date(year, month, day);
      };

      const date1 = parseDate(input1);
      const date2 = parseDate(input2);

      // 校验日期有效性
      if (!date1 || !date2 || isNaN(date1.getTime()) || isNaN(date2.getTime())) {
        $('#result').text('日期格式错误');
        return;
      }

      // 计算年份差(仅年份数值相减)
      const years = date2.getFullYear() - date1.getFullYear();
      $('#result').text(Math.max(0, years)); // 确保不为负数
    }
  </script>
</body>
</html>

⚠️ 关键注意事项

  • 勿直接 new Date("02/05/2023"):该字符串在 Chrome 中按 mm/dd/yyyy 解析,在 Firefox 中行为不一。务必使用 parseDate() 手动拆分处理,保障跨浏览器一致性。
  • .html() vs .append():使用 $('#result').html(...) 替代 .append(),避免重复追加内容;同时建议初始化时设为 '—' 提升用户体验。
  • 边界情况处理:添加空值校验、日期有效性检查(isNaN(date.getTime()))及负值防护(Math.max(0, years)),防止异常输入导致界面错乱。
  • 语言与本地化:通过引入 bootstrap-datepicker.zh-CN.min.js 并设置 language: 'zh-CN',确保日历显示符合中文习惯。
  • 扩展建议:若需支持“是否满整年”逻辑(例如 2023-06-01 至 2027-05-31 应返回 3 而非 4),则需比较月日,此时推荐使用 Luxon 或原生 Date 的 getMonth()/getDate() 组合判断。

该方案轻量、健壮、开箱即用,适用于合同年限、会员有效期、统计周期等典型业务场景。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

932

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

776

2023.11.06

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

508

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

214

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1550

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

640

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

842

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

814

2024.04.29

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

4

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

HTML+CSS基础与实战
HTML+CSS基础与实战

共132课时 | 10.9万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号