实际项目中,在用户的个人中心,编辑用户资料时经常会遇到选择生日选项的问题。

因为我项目工程中没有使用如jQuery UI的插件性下拉列表,所以选择select + option的原生方式,实现选择器。

能够准确计算闰年的年月日,方便表单处理。

实际效果如下图,式样略粗糙

HTML

生日中的年月日以<select>下拉方式,我们给每个select加个rel的属性,当已知用户生日时,直接通过rel属性标注,插件会将rel属性的数值转换成select的值。

jQuery

$.date_picker({

YearSelector:  "#date-sel-year",

MonthSelector: "#date-sel-month",

DaySelector:   "#date-sel-day"

});

$.ms_DatePicker();

******

实际使用,最终提交时,需要获得用户输入的生日,直接 $('#date-sel-year').val() 可以获得select的内容,

有时页面逻辑是,显示生日,用户点击 [编辑] 按钮后,初始化select的内容,此时用 $('#date-sel-year').val(year) 可以完成赋值的操作。

这时候,需要注意的是,很多生日显示时,会显示为,2015-09-01,但是直接赋值 09 给date-sel-month,是不能正确显示的。

需要判断如果变量第一个字符是0,要将第二位的字符赋值给select。

******

以下是插件的具体代码:

(function($){  
        $.extend({  
            date_picker: function(options){  
                var defaults = {  
                    YearSelector: "#sel_year",  
                    MonthSelector: "#sel_month",  
                    DaySelector: "#sel_day",  
                    FirstText: "--",  
                    FirstValue: 0  
                };  
                var opts = $.extend({}, defaults, options);  
                var $YearSelector = $(opts.YearSelector);  
                var $MonthSelector = $(opts.MonthSelector);  
                var $DaySelector = $(opts.DaySelector);  
                var FirstText = opts.FirstText;  
                var FirstValue = opts.FirstValue;  
          
                // 初始化  
                var str = "<option value=\"" + FirstValue + "\">" + FirstText + "</option>";  
                $YearSelector.html(str);  
                $MonthSelector.html(str);  
                $DaySelector.html(str);  
          
                // 年份列表  
                var yearNow = new Date().getFullYear();  
                var yearSel = $YearSelector.attr("rel");  
                for (var i = yearNow; i >= 1900; i--) {  
                    var sed = yearSel==i?"selected":"";  
                    var yearStr = "<option value=\"" + i + "\" " + sed+">" + i + "</option>";  
                    $YearSelector.append(yearStr);  
                }  
          
                // 月份列表  
                var monthSel = $MonthSelector.attr("rel");  
                for (var i = 1; i <= 12; i++) {  
                    var sed = monthSel==i?"selected":"";  
                    var monthStr = "<option value=\"" + i + "\" "+sed+">" + i + "</option>";  
                    $MonthSelector.append(monthStr);  
                }  
          
                // 日列表(仅当选择了年月)  
                function BuildDay() {  
                    if ($YearSelector.val() == 0 || $MonthSelector.val() == 0) {  
                        // 未选择年份或者月份  
                        $DaySelector.html(str);  
                    } else {  
                        $DaySelector.html(str);  
                        var year = parseInt($YearSelector.val());  
                        var month = parseInt($MonthSelector.val());  
                        var dayCount = 0;  
                        switch (month) {  
                            case 1:  
                            case 3:  
                            case 5:  
                            case 7:  
                            case 8:  
                            case 10:  
                            case 12:  
                                dayCount = 31;  
                                break;  
                            case 4:  
                            case 6:  
                            case 9:  
                            case 11:  
                                dayCount = 30;  
                                break;  
                            case 2:  
                                dayCount = 28;  
                                if ((year % 4 == 0) && (year % 100 != 0) || (year % 400 == 0)) {  
                                    dayCount = 29;  
                                }  
                                break;  
                            default:  
                                break;  
                        }  
                          
                        var daySel = $DaySelector.attr("rel");  
                        for (var i = 1; i <= dayCount; i++) {  
                            var sed = daySel==i?"selected":"";  
                            var dayStr = "<option value=\"" + i + "\" "+sed+">" + i + "</option>";  
                            $DaySelector.append(dayStr);  
                        }  
                    }  
                }  
                $MonthSelector.change(function () {  
                    BuildDay();  
                });  
                $YearSelector.change(function () {  
                    BuildDay();  
                });  
                if($DaySelector.attr("rel")!=""){  
                    BuildDay();  
                }  
            }  
        });  
    })(jQuery);

jQuery select年月日(生日)选择器的更多相关文章

  1. jQuery入门(1)jQuery中万能的选择器

    jQuery入门(1)jQuery中万能的选择器 jQuery入门(2)使用jQuery操作元素的属性与样式 jQuery入门(3)事件与事件对象 jQuery入门(4)jQuery中的Ajax()应 ...

  2. 从零开始学习jQuery (二) 万能的选择器

    本系列文章导航 从零开始学习jQuery (二) 万能的选择器 一.摘要 本章讲解jQuery最重要的选择器部分的知识. 有了jQuery的选择器我们几乎可以获取页面上任意的一个或一组对象, 可以明显 ...

  3. 前端基础-jQuery的内容之选择器

    阅读目录 ID选择器 类选择器 元素选择器 通配符选择器 层级选择器 基本筛选器 内容筛选器 可见性筛选器 属性筛选器 子元素筛选器 表单元素筛选器 表单对象筛选器 this和$(this) 一.jQ ...

  4. 第一百六十八节,jQuery,表单选择器

    jQuery,表单选择器 学习要点: 1.常规选择器 2.表单选择器 3.表单过滤器 表单作为 HTML 中一种特殊的元素,操作方法较为多样性和特殊性,开发者不但可以 使用之前的常规选择器或过滤器,也 ...

  5. jQuery中的:input选择器

    jQuery中的:input选择器 jQuery中的:input选择器包含input, textarea, select 和 button这些标签. <!DOCTYPE html> < ...

  6. Jquery | 基础 | 使用 jQuery 表单过滤选择器

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. jquery select取值,赋值操作

    select">jquery select取值,赋值操作 一.获取Select 获取select 选中的 text : $("#ddlRegType").find( ...

  8. jquery笔记之属性选择器 查找以某种条件开头的页面元素

    jquery笔记之属性选择器 查找以某种条件开头的页面元素 转载:http://www.blogbus.com/amyqiong-logs/78340326.html $("div[id]& ...

  9. jquery select选中表单特效三级联动

    好久没发帖了,今天发一个jquery select的表单三级联动,希望能对有需要的朋友有点帮助. js代码,当然还要加上jquery的包,应该都有的,这里就不发了. <script type=& ...

随机推荐

  1. GCC编译动态和静态链接库例子

    我们通常把一些公用函数制作成函数库,供其它程序使用.函数库分为静态库和动态库两种.静态库在程序编译时会被连接到目标代码中,程序运行时将不再需要该静态库.动态库在程序编译时并不会被连接到目标代码中,而是 ...

  2. ym——优化你的Java代码(新)

    转载请注明本文出自Cym的博客(http://blog.csdn.net/cym492224103),谢谢支持! 1.面向对象的3要素. 2.面向对象开发的6大原则. 1.单一职责原则 应该有且仅有一 ...

  3. 论持久战之PHPStorm Xdebug Remote 调试环境搭建(不依赖本地环境)

    最近公司自己搭建了一个资源管理平台,哈哈,当然是我在github上找的,后台用PHP开发.个人觉得写得非常nice,web页面几乎模拟了真实OS,有兴趣的朋友下载部署体验https://github. ...

  4. 另外几种Java集合框架具体解释续

    另外几种Java集合框架具体解释续 作者:chszs,未经博主同意不得转载.经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs fastutil库优于Trove库的 ...

  5. aix用户登录次数受限问题(3004-300 输入了无效的登录名或password)

    当登录AIX系统.username或password不对以至于多次登录,超过系统设定的次数,怎样解锁: 1.用root用户登录系统 2.chuser unsuccessful_login_count= ...

  6. hdu 1251 统计

    他妹的.敲完了.电脑死机了,所有消失了,又从新打了一遍,... 这是什么节奏 #include <stdio.h> #include <string.h> #include & ...

  7. scrapy框架的解析

    1,scrapy框架的官网:https://scrapy.org/ 什么是scrapy框架: scrapy 是一个为了爬取网站数据,提取结构性数据而编写的应用内框架,非常出名,所谓框架就是一个已经继承 ...

  8. Windows的MAX_PATH

    MAX_PATH的解释: 文件名最长256(ANSI),加上盘符(X:\)3字节,259字节,再加上结束符1字节,共260http://msdn.microsoft.com/en-us/library ...

  9. iOS SHA加密算法的实现

    - (NSString *)SHAStringWithSourceData:(NSData *)data type:(SHAType)type{ int shaDigestLength; switch ...

  10. mongo12---手动预先分片

    手动预先分片:(每个片上的数据是不一样的,是分开存,不是做备份) 自动分片有可能短期内某个片的数据过大,硬盘不够用了.能否100000-30000就到1号片. //以shop.user表为例,先声明s ...