欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用select實現(xiàn)年月日三級聯(lián)動的日期選擇效果【推薦】

 更新時間:2016年12月13日 14:45:23   作者:小火柴的藍(lán)色理想  
關(guān)于select控件,可能年月日三級聯(lián)動的日期選擇效果是最常見的應(yīng)用了。本文將對日期選擇效果進(jìn)行詳細(xì)介紹。需要的朋友一起來看下吧

前面的話

關(guān)于select控件,可能年月日三級聯(lián)動的日期選擇效果是最常見的應(yīng)用了。本文是選擇框腳本的實踐,下面將對日期選擇效果進(jìn)行詳細(xì)介紹

規(guī)劃

    默認(rèn)情況下,年、月、日分別由3個select控件組成,id分別為sel1,sel2,sel3。它們且所包含的option[0]的值,分別為'年'、'月'、'日'

 年份范圍為1900-2100,月份范圍為1-12,天的范圍為1-31

 年份范圍、月份范圍是不變的。而天的范圍根據(jù)實際日期的計算來改變其范圍值

 id為result的span元素儲存最終選擇的日期值及對應(yīng)的星期值

<div id="box">
 <select name="sel1" id="sel1">
 <option value="year">年</option>
 </select>
 <select name="sel2" id="sel2">
 <option value="month">月</option>
 </select>
 <select name="sel3" id="sel3">
 <option value="day">日</option>
 </select>
 <span id="result"></span>
</div>

結(jié)構(gòu)生成

由于數(shù)據(jù)太過龐大,所以使用javascript生成的方式生成結(jié)構(gòu)

//生成1900年-2100年
for(var i = 1900; i<=2100;i++){
 var option = document.createElement('option');
 option.setAttribute('value',i);
 option.innerHTML = i;
 sel1.appendChild(option);
}
//生成1月-12月
for(var i = 1; i <=12; i++){
 var option = document.createElement('option');
 option.setAttribute('value',i);
 option.innerHTML = i;
 sel2.appendChild(option); 
}
//生成1日—31日
for(var i = 1; i <=31; i++){
 var option = document.createElement('option');
 option.setAttribute('value',i);
 option.innerHTML = i;
 sel3.appendChild(option); 
}

算法處理

 算法的實質(zhì)就是確定某年某月到底有多少天,然后對多余的天數(shù)進(jìn)行刪除或者對少的天數(shù)進(jìn)行添加

【1】閏年

 年分為閏年和平年,平年有365天,閏年有366天。閏年的2月比平年多一天

 閏年的定義是(可被4整除)且((不可被100整除)或(可被400整除))的年份

 口訣是:四年一閏,百年不閏,四百年再閏

if((year % 4 === 0 && year % 100 !== 0) || year % 400 === 0){
 return 'leap year'
}else{
 return 'common year'
}

【2】大小月

 一年有12個月,其中4、6、9、11月每月有30天;如果是閏年,2月有29天,否則 ,2月有28天。1、3、5、7、8、10、12月每月有31天

if(month == 2){
 //如果是閏年
 if((year % 4 === 0 && year % 100 !== 0) || year % 400 === 0){
 days = 29;
 //如果是平年
 }else{
 days = 28;
 }
//如果是第4、6、9、11月
}else if(month == 4 || month == 6 ||month == 9 ||month == 11){
 days = 30;
}else{
 days = 31;
}

【3】增減情況

  考慮特殊情況,如果先選擇31日,再選擇2月,則發(fā)生錯誤。所以,選擇年份時,月份和天數(shù)自動置為默認(rèn)值'月'和'日',天數(shù)的范圍重置為'31'

//年份點擊
sel1.onclick = function(){
 //月份顯示默認(rèn)值
 sel2.options[0].selected = true;
 //天數(shù)顯示默認(rèn)值
 sel3.options[0].selected = true;
}

選擇月份時,天數(shù)自動置為默認(rèn)值'日',天數(shù)的范圍根據(jù)計算顯示相應(yīng)天數(shù)

此時,天數(shù)可能為28、29、30、31四種情況

//增加或刪除天數(shù)
 //如果是28天,則刪除29、30、31天(即使他們不存在也不報錯)
 if(days == 28){
 sel3.remove(31);
 sel3.remove(30);
 sel3.remove(29);
 }
 //如果是29天
 if(days == 29){
 sel3.remove(31);
 sel3.remove(30);
 //如果第29天不存在,則添加第29天
 if(!sel3.options[29]){
  sel3.add(new Option('29','29'),undefined)
 }
 }
 //如果是30天
 if(days == 30){
 sel3.remove(31);
 //如果第29天不存在,則添加第29天
 if(!sel3.options[29]){
  sel3.add(new Option('29','29'),undefined)
 }
 //如果第30天不存在,則添加第30天
 if(!sel3.options[30]){
  sel3.add(new Option('30','30'),undefined)
 }
 }
 //如果是31天
 if(days == 31){
 //如果第29天不存在,則添加第29天
 if(!sel3.options[29]){
  sel3.add(new Option('29','29'),undefined)
 }
 //如果第30天不存在,則添加第30天
 if(!sel3.options[30]){
  sel3.add(new Option('30','30'),undefined)
 }
 //如果第31天不存在,則添加第31天
 if(!sel3.options[31]){
  sel3.add(new Option('31','31'),undefined)
 }
 }

【4】結(jié)果顯示

每次年、月、日的點擊事件,都判斷年份、月份和天數(shù)是否都已經(jīng)設(shè)置為非默認(rèn)值。如果是的,則顯示最終結(jié)果,并計算星期值;如果不是,則什么都不執(zhí)行

//星期格式切換
function changDay(num){
 switch(num){
 case 0:
  return '日';
 case 1:
  return '一';
 case 2:
  return '二';
 case 3:
  return '三';
 case 4:
  return '四';
 case 5:
  return '五';
 case 6:
  return '六';  
 }
}
//結(jié)果顯示
box.onclick = function(){
 //當(dāng)年、月、日都已經(jīng)為設(shè)置值時
 if(sel1.value !='year' && sel2.value != 'month' && sel3.value !='day'){
 var day = new Date(sel1.value,sel2.value-1,sel3.value).getDay();
 result.innerHTML = sel1.value + '年' + sel2.value + '月' + sel3.value + '日' + '星期' + changDay(day);
 }else{
 result.innerHTML = '';
 }
}

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

相關(guān)文章

  • Bootstrap實現(xiàn)的表格合并單元格示例

    Bootstrap實現(xiàn)的表格合并單元格示例

    這篇文章主要介紹了Bootstrap實現(xiàn)的表格合并單元格,涉及bootstrap界面布局相關(guān)操作技巧,需要的朋友可以參考下
    2018-02-02
  • 生產(chǎn)制造追溯系統(tǒng)之在線打印功能

    生產(chǎn)制造追溯系統(tǒng)之在線打印功能

    這篇文章主要介紹了生產(chǎn)制造追溯系統(tǒng)之在線打印功能,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-06-06
  • 刷新頁面后讓控制臺的js代碼繼續(xù)執(zhí)行

    刷新頁面后讓控制臺的js代碼繼續(xù)執(zhí)行

    這篇文章主要介紹了刷新頁面后讓控制臺的js代碼繼續(xù)執(zhí)行,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • 使用js在layui中實現(xiàn)上傳圖片壓縮

    使用js在layui中實現(xiàn)上傳圖片壓縮

    這篇文章主要介紹了使用js在layui中實現(xiàn)上傳圖片壓縮,layui 是一款采用自身模塊規(guī)范編寫的前端 UI 框架,js上傳圖片壓縮百度有很多方法,,需要的朋友可以參考下
    2019-06-06
  • XML、HTML、CSS與JS的區(qū)別整理

    XML、HTML、CSS與JS的區(qū)別整理

    在BS中,xml,html,css和js我們都學(xué)過,起初分不清這四者的區(qū)別和聯(lián)系,隨著知識的增長,有了一些體會,下面通過本文給大家簡單介紹 XML、HTML、CSS與JS的區(qū)別,需要的朋友參考下
    2016-02-02
  • js校驗表單后提交表單的三種方法總結(jié)

    js校驗表單后提交表單的三種方法總結(jié)

    本篇文章主要是對js校驗表單后提交表單的三種方法進(jìn)行了總結(jié)介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-02-02
  • JavaScript中立即執(zhí)行函數(shù)實例詳解

    JavaScript中立即執(zhí)行函數(shù)實例詳解

    javascript和其他編程語言相比比較隨意,所以javascript代碼中充滿各種奇葩的寫法,有時霧里看花,當(dāng)然,能理解各型各色的寫法也是對javascript語言特性更進(jìn)一步的深入理解。這篇文章主要給大家介紹了關(guān)于JavaScript中立即執(zhí)行函數(shù)的相關(guān)資料,需要的朋友可以參考下。
    2017-11-11
  • Object.keys()、Object.values()、Object.entries()用法總結(jié)

    Object.keys()、Object.values()、Object.entries()用法總結(jié)

    本文主要介紹了Object.keys()、Object.values()、Object.entries()用法總結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • JS前端框架關(guān)于重構(gòu)的失敗經(jīng)驗分享

    JS前端框架關(guān)于重構(gòu)的失敗經(jīng)驗分享

    關(guān)于重構(gòu)JS前端框架的失敗經(jīng)驗接下來與大家分享一下,感興趣的你可不要錯過了哈,畢竟是經(jīng)驗之談哈
    2013-03-03
  • js字符串完全替換函數(shù)分享

    js字符串完全替換函數(shù)分享

    用JS替換字符串時。只能替換掉字符串中第一個匹配對象,有時候需要替換全部的字符,下文是具體的實現(xiàn)方法,大家可以參考下
    2014-12-12

最新評論