我正在尝试创建一个下拉列表,该列表将自动在文本字段中输入日期。
选项“ LBD”当前返回昨天的日期,但是,我希望它返回上一个工作日的日期。因此,如果今天是星期一,它将返回星期五的日期,如果今天是星期二,则将返回星期一的日期。等等等等。
到目前为止,这是我得到的:
Javascript:
<script>
$(document).ready(function() {
$("#datetype option").filter(function() {
return $(this).val() == $("#datepickstart").val();
return $(this).val() == $("#datepickend").val();
}).attr('selected', true);
var d = new Date();
var yesterday = (d.getMonth() + 1) + "/" + (d.getDate() - 1) + "/" + d.getFullYear();
var today = (d.getMonth() + 1) + "/" + d.getDate() + "/" + d.getFullYear();
var fdm = (d.getMonth() + 1) + '/01/' + d.getFullYear();
var fdy = '01/01/' + new Date().getFullYear();
$("#datetype").on("change", function() {
var selectedVal = $(this).find("option:selected").attr("value");
if (selectedVal == 'LBD') {
$("#datepickstart").val((yesterday));
$("#datepickend").val((yesterday));
}
if (selectedVal == 'MtD') {
$("#datepickstart").val(fdm);
$("#datepickend").val(today);
}
if (selectedVal == 'YtD') {
$("#datepickstart").val(fdy);
$("#datepickend").val(today);
}
});
})
</script>
Run Code Online (Sandbox Code Playgroud)
的HTML:
<select id="datetype" name="datetype">
<option value="">Please select...</option>
<option value="LBD">LBD</option>
<option value="MtD">MtD</option>
<option value="YtD">YtD</option>
</select>
<input type="text" id="datepickstart" name="datepickstart" value="">
<input type="text" id="datepickend" name="datepickend" value="">
Run Code Online (Sandbox Code Playgroud)
getDay()函数是解决问题的关键。我使用@zzzzBov片段进行迭代。下面是我的解决方案
step1:
function isBusinessDay(date){
var day = date.getDay();
if(day == 0 || day == 6 ){
return false;
}
return true;
}
step2:
var date = new Date();
while (!isBusinessDay(date)) { date.setDate(date.getDate() - 1) }
console.log(date);//date always between monday to friday
Run Code Online (Sandbox Code Playgroud)
希望这能解决您的问题。编码愉快!!
为了达到您的预期结果,请计算天数并减少天数以获得前一个工作日。
$(document).ready(function() {
$("#datetype option").filter(function() {
return $(this).val() == $("#datepickstart").val();
return $(this).val() == $("#datepickend").val();
}).attr('selected', true);
var d = new Date();
var bd = d.getDay();
if (bd < 2) {
if (bd == 0) {
bd = 2;
} else {
bd = 3;
}
} else {
bd = 1;
}
var today = (d.getMonth() + 1) + "/" + d.getDate() + "/" + d.getFullYear();
var lbd = (d.getMonth() + 1) + "/" + (d.getDate() - bd) + "/" + d.getFullYear();
var fdm = (d.getMonth() + 1) + '/01/' + d.getFullYear();
var fdy = '01/01/' + new Date().getFullYear();
$("#datetype").on("change", function() {
var selectedVal = $(this).find("option:selected").attr("value");
if (selectedVal == 'LBD') {
$("#datepickstart").val(lbd);
$("#datepickend").val(today);
}
if (selectedVal == 'MtD') {
$("#datepickstart").val(fdm);
$("#datepickend").val(today);
}
if (selectedVal == 'YtD') {
$("#datepickstart").val(fdy);
$("#datepickend").val(today);
}
});
});
Run Code Online (Sandbox Code Playgroud)
Codepen- http://codepen.io/nagasai/pen/wWgQYE
LBD计算部分
var bd = d.getDay();// get day from today's date which be between 0-6 (0 is Sunday and 6 is Saturday
if (bd < 2) {
if (bd == 0) {
bd = 2;
} else {
bd = 3;
}
} else {
bd = 1;
}
//variable lbd will get the last business day by reducing the calculated lbd from today's date
var lbd = (d.getMonth() + 1) + "/" + (d.getDate() - bd) + "/" + d.getFullYear();
Run Code Online (Sandbox Code Playgroud)