Maison >interface Web >js tutoriel >Comment utiliser le contrôle du temps jquery UI Datepicker (version finale)_jquery
J'ai utilisé des contrôles de date dans des projets récents et je me sens bien. Je vais l'écrire et le partager avec tout le monde. Je limite l'heure de début et l'heure de fin à trois jours maximum, et je le configure avec. des fonctions telles que l'effacement de l'heure et la resélection de l'heure. Partagez-la avec tout le monde :
.
Laissez-moi d'abord vous montrer deux rendus
Dans l'exemple, l'heure de début et l'heure de fin que je contrôle sont de trois jours, c'est-à-dire que l'intervalle entre l'heure de début et l'heure de fin ne peut pas dépasser trois jours.
Comment l'implémenter spécifiquement ? Il y aura une explication détaillée dans le code. Veuillez continuer à lire :
La première étape consiste à introduire le contrôle js. Il y en a deux ici, l'un est jquery.js, l'autre est jquery-ui-datepicker.js, et bien sûr, introduisez le fichier de style :
<script type="text/javascript" src="js/jquery.js"></script> <script type="text/javascript" src="js/jquery-ui-datepicker.js"></script> <link rel="stylesheet" type="text/css" href="css/jquery-ui.css" />
Étape 2 : Créer une zone de saisie de texte, une saisie de type texte. Ma démo comprend également le réglage du temps d'effacement, qui est un événement de réponse de bouton
.<td width="35%"> <label>开始时间:</label> <input type="text" name="start" id="start" value="${params.start}" readonly="true" title="日期范围不能大于3天"/> <input type="button" class="formButton" value="清空" onclick="cleaPrevInput(this);"/> <font color="red">必选*</font> </td> <td width="35%"> <label>结束时间:</label> <input type="text" name="end" id="end" value="${params.end}" readonly="true" title="日期范围不能大于3天"/> <input type="button" class="formButton" value="清空" onclick="cleaPrevInput(this);"/> <font color="red">必选*</font> </td>
Ne vous inquiétez pas de la valeur à l'intérieur. C'est le code que j'ai écrit dans le projet. La valeur est écrite comme ceci afin que lorsque la page est actualisée après l'interrogation, il puisse toujours y avoir une valeur de temps sélectionnée dans la zone de temps. .
Le code suivant est pour appeler le contrôle de date. Le code est le suivant :
$(function(){ // 获取调用控件的对象 var dates = $("#start,#end"); var option; //设置目标时间,因为例子中的开始时间和结束时间是有时间限制的 var targetDate; var optionEnd; var targetDateEnd; dates.datepicker({ showButtonPanel:false, //当选择时间的时候触发此事件 onSelect: function(selectedDate){ if(this.id == "start"){ // 如果是选择了开始时间 option = "minDate"; //getTimeByDateStr 这个方法的代码下面会贴出来的,就是处理时间的代码 var selectedTime = getTimeByDateStr(selectedDate); var minTime = selectedTime; targetDate = new Date(minTime); //设置结束时间 optionEnd = "maxDate"; targetDateEnd = new Date(minTime+2*24*60*60*1000); }else{ // 如果是选择了结束时间 option = "maxDate"; var selectedTime = getTimeByDateStr(selectedDate); var maxTime = selectedTime; targetDate = new Date(maxTime); //设置开始时间 optionEnd = "minDate"; targetDateEnd = new Date(maxTime-2*24*60*60*1000); } //设置时间框中时间,比如根据选择的开始时间,限制结束时间的不可选项,dates.not(this)是js选择器使用, //datepicker("option", option, targetDate),这个就是日期控件封装的api了 dates.not(this).datepicker("option", option, targetDate); dates.not(this).datepicker("option", optionEnd, targetDateEnd); } }); });
Publions maintenant le code de la méthode getTimeByDateStr(XXX) dans le code ci-dessus pour la commodité de tous. Ce code est très simple et je pense que tout le monde peut le comprendre d'un coup d'œil :
//根据日期字符串取得其时间 function getTimeByDateStr(dateStr){ var year = parseInt(dateStr.substring(0,4)); var month = parseInt(dateStr.substring(5,7),10)-1; var day = parseInt(dateStr.substring(8,10),10); return new Date(year, month, day).getTime(); }
Le code peut désormais implémenter l'utilisation de contrôles de date, et l'heure de début et l'heure de fin sont limitées à trois jours. Par exemple, si vous choisissez l'heure de début au 27/03/2014, l'heure de fin est uniquement. 27, 28 et 29. Facultatif, les dates restantes ne sont pas cliquables. Si vous choisissez l'heure de fin à 28, alors l'heure de début ne peut désormais être que 28, 27, 26, c'est tout.
Étape 3 : Regardez le bouton d'effacement. Le bouton d'effacement consiste à effacer la valeur dans la zone de sélection de l'heure C'est très simple à mettre en œuvre :
.//清空日历控件 function cleaPrevInput(objs){ //清空输入框中的值,但是仅仅是清空了值而已,时间控件的选值限制还在的 $(objs).prev().val(""); //如果开始时间和结束时间都清空了,这时应该是你选择的那个框中是没有时间限制的,也就是说可以随便选择日期 if($('#start').val()=="" && $('#end').val()==""){ var dates = $("#start,#end"); //调用datepicker封装的api,使刚刚设置的开始时间和结束时间为空,这样就可以选择任意日期了 dates.datepicker("option", "minDate", null); dates.datepicker("option", "maxDate", null); } }
Il peut être utilisé maintenant. Si vous utilisez simplement le contrôle, c'est très simple sans fixer de limite de temps. Le code ci-dessus peut être utilisé pour la plupart des besoins de sélection de date, mais s'il y a quelque chose de spécial, vous devez quand même vérifier. l'API vous-même. À ce moment-là, j'ai vérifié l'API pendant longtemps juste pour effacer la valeur dans le contrôle de date, qui est ce code : dates.datepicker("option", "maxDate", null J'ai encore besoin de tout le monde). avoir assez de patience.
Ce qui précède est l'introduction complète du contrôle temporel jquery UI Datepicker. Il est terminé pour le moment. S'il y a des articles connexes dans le futur, je les partagerai avec vous dès que possible.