全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

基于angular实现三级联动的生日插件

写了一个生日联动插件具体的效果是这样的:

具体的数据

我取得数据是今年的数据,如果是想要做三级联动的日期插件,改一下时间就好了

var app=angular.module("dataPicker",[])

app.factory('dataPicker', ['$http', '$q', function ($http, $q) {
  return {
   query: function () {
    var lengthYear=100;
    var dataPicker={
     month:[],
     year:[],
     day:[]
    };
    var data = new Date();
    var nowyear = data.getFullYear();
    for(var i=nowyear,j=0; i>nowyear-lengthYear;i--,j++){
     dataPicker.year[j]=i;
    }
    for(var i=0;i<=11;i++){
     if(i<9){
      dataPicker.month[i]='0'+(i+1);
     }else{
      dataPicker.month[i]=String(i+1);
     }
    }
    return dataPicker;
   }
  }
 }])

directive插件的主要内容

app.directive('selectDatepicker', function ($http,dataPicker) {
  return {
   restrict: 'EAMC',
   replace: false,
   scope: {
    birthday: '=birthday'
   },
   transclude: true,
   template: '<span>生日</span>'+
    '<select class="sel_year" ng-model="birY" ng-change="changeYear()"><option ng-repeat="x in yearAll">{{x}}</option></select>'+
    '<select class="sel_month" ng-model="birM" ng-change="changeMonth()" ng-disabled="birY==\'\'"><option ng-repeat="x in MonthAll">{{x}}</option> </select>'+
    '<select class="sel_day" ng-model="birD" ng-disabled="birM==\'\'" ng-change="changeDay()"><option ng-repeat="x in DayAll">{{x}}</option></select>',
   link: function (scope, element){
    var arr=[];
    scope.birthday=scope.birthday=='0000-00-00'?"":scope.birthday
    var shuju=dataPicker.query()
    scope.yearAll=shuju.year;
    scope.MonthAll=shuju.month;
    if(scope.birthday){
     scope.birY=scope.birthday.birthday.split('-')[0];
     scope.birM=String(scope.birthday.birthday.split('-')[1])
    }else{
     scope.birY="";
     scope.birM="";
    }
    scope.getDaysInOneMonth=function(year, month){
     var month1 = Number(month);
     month1=parseInt(month1,10)
     var d= new Date(Number(year),month1,0);
     return d.getDate();
    }
    scope.getDayArr=function(day){
     shuju.day=[];
     for(var i=0; i<day;i++){
      if(i<9){
       shuju.day[i]='0'+(i+1)
      }else{
       shuju.day[i]=String((i+1));
      }
     }
    }
    if(scope.birthday){
     var day=scope.getDaysInOneMonth(scope.birthday.birthday.split('-')[0],scope.birthday.birthday.split('-')[1]);
     scope.getDayArr(day)
     scope.DayAll=shuju.day;
     scope.birD=scope.birthday.birthday.split('-')[2]
    }
    scope.changeYear=function(){
     scope.birD="";
     scope.birM="";
    }
    scope.changeMonth=function(){
     var day=scope.getDaysInOneMonth(scope.birY,scope.birM);
     console.log(day)
     scope.getDayArr(day);
     scope.DayAll=shuju.day;
     scope.birD="";
    }
    scope.changeDay=function(){
     scope.returnDate();
    }
    scope.returnDate=function(){
     if(!scope.birD||!scope.birY||!scope.birM){
      scope.birthday.returnValue="";
     }else{
      arr[0]=scope.birY;
      arr[1]=scope.birM;
      arr[2]=scope.birD;
      scope.birthday.returnValue=arr.join("-");
     }
    }
   }
  }
 })
});

 html

<div select-datepicker birthday="birthday"> 

js 传入的数据

 $scope.birthday={
   birthday:1993-01-20,
   returnValue:'',
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# angular三级联动插件  # angular生日插件  # angular三级联动日期插件  # AngularJS实现的select二级联动下拉菜单功能示例  # Angularjs实现下拉框联动的示例代码  # Angularjs自定义指令实现三级联动 选择地理位置  # 基于AngularJs + Bootstrap + AngularStrap相结合实现省市区联动代码  # 实例详解AngularJS实现无限级联动菜单  # AngularJS实现的省市二级联动功能示例【可对选项实现增删】  # 是这样  # 写了  # 主要内容  # 大家多多  # 就好了  # gt  # getFullYear  # lt  # month  # day  # year  # data  # nowyear  # Date  # String  # scope  # false  # birthday  # true  # transclude 


相关文章: 专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  高性价比服务器租赁——企业级配置与24小时运维服务  简单实现Android文件上传  如何通过西部数码建站助手快速创建专业网站?  c# 在ASP.NET Core中管理和取消后台任务  如何用y主机助手快速搭建网站?  如何在阿里云高效完成企业建站全流程?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  小说建站VPS选用指南:性能对比、配置优化与建站方案解析  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  建站上传速度慢?如何优化加速网站加载效率?  大同网页,大同瑞慈医院官网?  制作网站的基本流程,设计网站的软件是什么?  如何选择适配移动端的WAP自助建站平台?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?  如何在IIS管理器中快速创建并配置网站?  微课制作网站有哪些,微课网怎么进?  建站之星安装失败:服务器环境不兼容?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  再谈Python中的字符串与字符编码(推荐)  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  网站制作软件有哪些,制图软件有哪些?  如何快速搭建虚拟主机网站?新手必看指南  如何高效利用亚马逊云主机搭建企业网站?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  北京网站制作的公司有哪些,北京白云观官方网站?  如何选择高效可靠的多用户建站源码资源?  如何在橙子建站上传落地页?操作指南详解  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  如何在自有机房高效搭建专业网站?  如何在Windows 2008云服务器安全搭建网站?  存储型VPS适合搭建中小型网站吗?  建站之星如何取消后台验证码生成?  盘锦网站制作公司,盘锦大洼有多少5G网站?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  内部网站制作流程,如何建立公司内部网站?  如何通过FTP服务器快速搭建网站?  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  如何在阿里云完成域名注册与建站?  股票网站制作软件,网上股票怎么开户?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  如何通过可视化优化提升建站效果?  如何用搬瓦工VPS快速搭建个人网站?  如何在沈阳梯子盘古建站优化SEO排名与功能模块? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。