Maison >interface Web >js tutoriel >Comment implémenter la fonction de sélecteur de date en utilisant JavaScript ?

Comment implémenter la fonction de sélecteur de date en utilisant JavaScript ?

WBOY
WBOYoriginal
2023-10-20 16:54:191315parcourir

如何使用 JavaScript 实现日期选择器功能?

Comment implémenter la fonction de sélecteur de date en utilisant JavaScript ?

【Introduction】
Le sélecteur de dates est l'une des fonctions courantes dans le développement Web, qui peut fournir aux utilisateurs un moyen pratique et rapide de sélectionner des dates. Cet article explique comment implémenter un sélecteur de date simple à l'aide de JavaScript et fournit des exemples de code détaillés.

【Étapes de mise en œuvre】

1. Structure HTML
Tout d'abord, ajoutez une zone de saisie et un bouton au HTML pour déclencher la fenêtre contextuelle du sélecteur de date.

<input type="text" id="dateInput">
<button type="button" onclick="showDatePicker()">选择日期</button>

2. Styles CSS
Afin que la fenêtre contextuelle du sélecteur de date s'affiche magnifiquement, vous pouvez y ajouter des styles.

#datePicker {
  position: absolute;
  background-color: #fff;
  padding: 10px;
  border: 1px solid #ccc;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
  z-index: 9999;
}

3. Implémentation de JavaScript
Ensuite, utilisez JavaScript pour implémenter la fonction de sélecteur de date.

// 获取日期选择器弹窗和日期输入框元素
var datePicker = document.createElement("div");
datePicker.setAttribute("id", "datePicker");
var dateInput = document.getElementById("dateInput");

// 显示日期选择器弹窗
function showDatePicker() {
  // 获取输入框位置和大小
  var rect = dateInput.getBoundingClientRect();
  
  // 设置日期选择器弹窗位置
  datePicker.style.left = rect.left + "px";
  datePicker.style.top = (rect.top + rect.height) + "px";
  
  // 清空日期选择器弹窗内容
  datePicker.innerHTML = "";
  
  // 创建日期选择器表格
  var table = document.createElement("table");
  
  // 创建表头
  var thead = document.createElement("thead");
  var tr = document.createElement("tr");
  var th = document.createElement("th");
  th.textContent = "日";
  tr.appendChild(th);
  // ...省略其他表头代码...
  thead.appendChild(tr);
  table.appendChild(thead);
  
   // 创建日期选择器内容(示例为一个月的数据)
  var tbody = document.createElement("tbody");
  for (var i = 1; i <= 30; i++) {
    var tr = document.createElement("tr");
    for (var j = 1; j <= 7; j++) {
      var td = document.createElement("td");
      td.textContent = i + (j - 1) * 7;
      tr.appendChild(td);
    }
    tbody.appendChild(tr);
  }
  table.appendChild(tbody);
  
  // 将日期选择器表格添加到弹窗
  datePicker.appendChild(table);
  
  // 将日期选择器弹窗添加到页面
  document.body.appendChild(datePicker);
}

// 隐藏日期选择器弹窗
function hideDatePicker() {
  // 判断点击事件是否在日期选择器内部,是则不隐藏
  var clickInside = false;
  var e = window.event;
  var target = e.target;
  while (target.parentNode) {
    if (target.parentNode === datePicker) {
      clickInside = true;
      break;
    }
    target = target.parentNode;
  }
  if (!clickInside) {
    document.body.removeChild(datePicker);
  }
}

// 点击页面其他地方时隐藏日期选择器弹窗
document.addEventListener("click", hideDatePicker);

【Comment utiliser】
Copiez le code ci-dessus dans un fichier HTML et enregistrez-le, puis ouvrez le fichier dans le navigateur. Cliquez sur le bouton « Sélectionner la date » et une fenêtre contextuelle de sélection de date apparaîtra. Cliquez ailleurs sur la page et la fenêtre contextuelle se masquera automatiquement.

【Résumé】
Il n'est pas difficile d'implémenter une simple fonction de sélection de date via JavaScript. Il vous suffit de créer dynamiquement des éléments, de définir des styles et des écouteurs d'événements. Les développeurs peuvent personnaliser et étendre le sélecteur de date en fonction des besoins réels pour le rendre plus adapté aux besoins du projet. N'oubliez pas que garantir la lisibilité et la maintenabilité du code et améliorer l'expérience utilisateur sont l'un des objectifs importants du processus de développement.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn