ios风格的时间选择插件

时间: 2018-11-17阅读: 1418标签: 插件

1.起因

在上个项目中,客户希望时间选择插件可以是ios风格的那种,但是找了很久,发现并没有用vue的ios风格时间插件,于是自己便自己造了一个轮子.


2.插件效果



3.插件依赖以及安装使用

插件依赖于better-scroll和vue,安装流程如下:

step1:  npm install vue -D
step2:  npm install better-scroll -D
step3:  npm install vue-ios-timer -D
step4:  import vueIosTimer from 'vue-ios-timer';
step5:  vue.use(vueIosTimer);


4.源码查看与调试

可以在我的Github上查看源码,或者已经下载过插件的同学可以在node_modules/vue-ios-timer/src/packages/timer.vue中查看,需要调试源码的同学可以将node_modules/package.json中main的value值改为src/packages/index.js,然后正常使用,其运行的代码便是node_modules/vue-ios-timer/src/packages/timer.vue中的代码.


5.实现思路

1) 生成年,月,日,时,分,五个数组,根据插件属性type(可选值有date,datetime,time)初始化timeList二维数组,并初始化初始值;

initBasicData(){
 
    for(let i=1900; i<=2100; i++){
        this.years.push(i+'年');
    }
 
    for(let i=0; i<60; i++){
        if(i>0 && i<=12){
            this.monthes.push(String(i).padStart(2,'0')+'月');
        }
        if(i>0 && i<=31){
            this.days.push(String(i).padStart(2,'0')+'日');
        }
        if(i<24){
            this.hours.push(String(i).padStart(2,'0')+'时');
        }
        this.minutes.push(String(i).padStart(2,'0')+'分');
    }
    // 当type=date并且有默认值时
    if(this.type == 'date' && this.datex){
        let y = new Date(this.datex).getFullYear();
        let m = new Date(this.datex).getMonth();
        let d = new Date(this.datex).getDate();
        this.timerSelectIndex = [y-1900, m, d-1];
    // 当type=datetime并且有默认值
    }else if(this.type == 'datetime' && this.datetimex){
        let y  = new Date(this.datetimex).getFullYear();
        let m  = new Date(this.datetimex).getMonth();
        let d  = new Date(this.datetimex).getDate();
        let h  = new Date(this.datetimex).getHours();
        let min= new Date(this.datetimex).getMinutes();
        this.timerSelectIndex = [y-1900, m, d-1, h, min];
    // 当type=time并且有默认值
    }else if(this.type == 'time' && this.timex){
        let h  = Number(this.timex.split(':')[0]);
        let min= Number(this.timex.split(':')[1]);
        this.timerSelectIndex = [h, min];
    }else{
        // 当没有默认值的时候
        this.timerSelectIndex = [0,0,0,0,0];
    }
},
initTimeList(){
    if(this.type == 'datetime'){
        this.timeList.push(this.years);
        this.timeList.push(this.monthes);
        this.timeList.push(this.days);
        this.timeList.push(this.hours);
        this.timeList.push(this.minutes);
    }else if(this.type == 'time'){
        this.timeList.push(this.hours);
        this.timeList.push(this.minutes);
    }else {
        this.timeList.push(this.years);
        this.timeList.push(this.monthes);
        this.timeList.push(this.days);
    }
},


2) 有了基础数据,通过better-scroll初始化滚动列表,better-scroll可以开启wheel选项,实现多列表的滚动交互,而后我们每个月的天数是有可能不一样的,所以需要动态的改变日数组,改变的时机应该是当年份列表滚动或者月份列表滚动结束的时候;

initScroll(){
    // 循环初始化多个列表
    if(!this.$refs.timerWrapper){
        return
    };
    let timerWrapper = this.$refs.timerWrapper;
 
    for(let i=0; i<timerWrapper.children.length; i++){
 
        let wheel = new Bscroll(timerWrapper.children[i],{
            wheel : {
                rotate : 25,
                selectedIndex : this.timerSelectIndex[i],
                wheelWrapperClass : 'wheel-scroll',
                wheelItemClass : 'wheel-item'
            },
            probeType : 3
        });
        this.wheels.push(wheel);
    }
 
    // 监听scrollEnd事件,当滚动结束以后,重新渲染天这一列
    this.wheels.forEach((wheel,i)=>{
        wheel.on('scrollEnd',(pos)=>{
            if((this.type == 'date' || this.type == 'datetime') && i != 2){
                let year    = 1900 + this.wheels[0].getSelectedIndex();
                let month   = this.wheels[1].getSelectedIndex()+1;
                let newDays = this.getDays(Number(year),Number(month));
 
                this.$set(this.timeList,2, newDays);
                this.wheels[2].refresh();
            }
        })
    })
},
getDays(year,month){
    // 根据年份和月份得到当月的天数
    let isLeapYear = (year % 400 == 0) || (year % 4 == 0 && year % 100 != 0);
    let bigMonthes = [1,3,5,7,8,10,12];
    let isBigMonth = bigMonthes.indexOf(month) > -1;
    let days = [];
 
    for(let i=1; i<=31; i++){
        days.push(String(i).padStart(2,"0")+'日');
    };
 
    if(isBigMonth){
        return days;
    }else if(isLeapYear && month == 2){
        return days.splice(1,29);
    }else if(!isLeapYear && month == 2){
        return days.splice(1,28);
    }else{
        return days.splice(1,30);
    }
}


3)  当用户所有的滚动操作结束以后,这时候需要通过发送getTime事件将选择结果暴露出去;

getIndex(){
 // 返回选中的值
 let indexes = [],result = '';
 this.wheels.forEach(wheel=>{
     indexes.push(wheel.getSelectedIndex())
 });
 
 if(indexes.length == 3 || indexes.length == 5){
     indexes = indexes.map((item,i)=>{
         if(i==0){
             item = 1900 + item;
         }else if(i==1 || i==2){
             item = String(item+1).padStart(2,'0');
         }else{
             item = String(item).padStart(2,'0');
         }
         return item;
     })
 }else{
     indexes = indexes.map((item,i)=>{
         item = String(item).padStart(2,'0');
         return item;
     })
 }
 
 if(indexes.length == 2){
     result = indexes.join(':');
 }else if(indexes.length == 3){
     result = indexes.join('-');
 }else{
     result = `${indexes[0]}-${indexes[1]}-${indexes[2]} ${indexes[3]}:${indexes[4]}`;
 }
  
 this.showTimer = false;
 this.$emit('getTime',result);
}


更多实现细节可以去看完整源码,以上。来源:https://www.cnblogs.com/024-faith/archive/2018/11/16/ios-timer.html


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: http://www.fly63.com/article/detial/1358

DefinePlugin插件用法理解

DefinePlugin 允许创建一个在编译时可以配置的全局常量。这可能会对开发模式和生产模式的构建允许不同的行为非常有用。如果在开发构建中,而不在发布构建中执行日志记录,则可以使用全局常量来决定是否记录日志。这就是 DefinePlugin 的用处

vue-cli3配置webpack-bundle-analyzer插件

为优化vue项目性能,需要使用webpack-bundle-analyzer分析报文件,找出最占用空间的插件有哪些,对应做出优化,网上看了一些网站,有的写的太麻烦了,现将最简单的一种写出来供大家参考

Vue中的JS与Velocity.js的结合

JS动画效果,注意事件函数中所传递的传递的参数及某些事件函数返回的函数1.进入动画钩子:before-enter,enter,after-enter;2.离开动画钩子:before-leave,leave,after-leave;3.在enter钩子中的函数调用done

chrome书签插件

Pinbox 是一款可以使得用户的Chrome书签变得更加生动的谷歌浏览器插件,用户在Chrome中安装了Pinbox插件以后,只需要点击一下扩展按钮就会自动为你把当前的网页保存到Pinbox中。

Pushbar.js带模糊效果的隐藏滑动侧边栏插件

Pushbar.js是一个小巧的Javascript插件,它可以用于在Web应用程序中创建滑动侧边栏效果,还提供模糊效果,就像开关抽屉的效果。你可以完全定制效果,它不依赖任何第三方库,你可以使用它作为侧栏菜单或者操作选项滑出效果。

浏览器插件_常用谷歌浏览器插件推荐

常用谷谷歌浏览器确实没有其它国产软件的内置功能丰富。但是 Google 浏览器的的优点恰恰就体现在拥有超简约的界面,以及支持众多强大好用的扩展程序,用户能够按照自己的喜好去个性化定制浏览器。今天我就给大家介绍几款自己常用的插件。

基于Vue的验证码插件vue2-verify

在我们Web项目开发中,验证码是一种比较常见的区分用户是计算机还是人的手段。主要是为了保证项目的安全。现在Vue开发的项目很多,基本都是前后端分离的。给大家推荐一个基于Vue比较好用的验证码插件vue2-verify。但是大家要注意一点

总结18个webpack插件

何为插件(Plugin)?专注处理 webpack 在编译过程中的某个特定的任务的功能模块,可以称为插件。Plugin 是一个扩展器,它丰富了 webpack 本身,针对是 loader 结束后,webpack 打包的整个过程

AnySlider:适用于任何Html内容的jQuery Slider插件

任何Slider都是一个易于使用且支持触摸的jQuery插件,允许您为任何html内容创建可自定义的滑块,如图像,文本,视频等。在页面上包含jQuery库和jQuery AnySlider

vue插件开发toast

在没有封装插件之前,如果不使用第三方插件,那么很多情况下我们会编写几个常用的组件来提供给页面使用,如Alert/Loading组件,而你可能需要在很多页面中引入并且通过components注册组件

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!