這次帶給大家怎樣利用源生JS實現出生日期下拉選單,利用源生JS實作出生日期下拉選單的注意事項有哪些,以下就是實戰案例,一起來看一下。
在製作網頁時,可能需要給用戶提供註冊帳號頁面,用戶註冊設計很多信息,其中就有關於出生日期的,出於用戶體驗,不想讓用戶手動輸入,而HTML5的date,目前很多瀏覽器支援的並不是很好,所以就可以用JS實現年、月、日3個下拉框的日期選擇。具體程式碼如下:
1、新建一個js文件,如birthday.js;
function DateSelector(selYear, selMonth, selDay) {//定义函数 this.selYear = selYear; this.selMonth = selMonth; this.selDay = selDay; this.selYear.Group = this; this.selMonth.Group = this; // 给年份、月份下拉菜单添加处理onchange事件的函数 if (window.document.all != null) // IE { this.selYear.attachEvent("onchange", DateSelector.Onchange); this.selMonth.attachEvent("onchange", DateSelector.Onchange); } else // Firefox { this.selYear.addEventListener("change", DateSelector.Onchange, false); this.selMonth.addEventListener("change", DateSelector.Onchange, false); } if (arguments.length == 4) // 如果传入参数个数为4,最后一个参数必须为Date对象 this.InitSelector(arguments[3].getFullYear(), arguments[3].getMonth() + 1, arguments[3].getDate()); else if (arguments.length == 6) // 如果传入参数个数为6,最后三个参数必须为初始的年月日数值 this.InitSelector(arguments[3], arguments[4], arguments[5]); else // 默认使用当前日期 { var dt = new Date(); this.InitSelector(dt.getFullYear(), dt.getMonth() + 1, dt.getDate()); } } // 增加一个最小年份的属性--最老年份 DateSelector.prototype.MinYear = 1960; // 增加一个最大年份的属性--最新年份,即当前时期getFullYear() DateSelector.prototype.MaxYear = (new Date()).getFullYear(); // 初始化年份 DateSelector.prototype.InitYearSelect = function () { // 循环添加OPION元素到年份select对象中 for (var i = this.MaxYear; i >= this.MinYear; i--) { // 新建一个OPTION对象 var op = window.document.createElement("OPTION"); // 设置OPTION对象的值 op.value = i; // 设置OPTION对象的内容 op.innerHTML = i; // 添加到年份select对象 this.selYear.appendChild(op); } } // 初始化月份 DateSelector.prototype.InitMonthSelect = function () { // 循环添加OPION元素到月份select对象中 for (var i = 1; i <p style="text-align: left;">2、在註冊表單中的頁面,引用剛才寫的js</p><pre class="brush:php;toolbar:false"><script></script> <select></select>年 <select></select>月 <select></select>日 <!--完成出生日期的选择--需写在</body>前--> <script> var selYear = window.document.getElementById("selYear"); var selMonth = window.document.getElementById("selMonth"); var selDay = window.document.getElementById("selDay"); // 新建一个DateSelector类的实例,将三个select对象传进去 new DateSelector(selYear, selMonth, selDay, 1995, 1, 17); </script>
以上是如何利用源生JS實現出生日期下拉式選單的詳細內容。更多資訊請關注PHP中文網其他相關文章!