全网整合营销服务商

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

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

基于Vue实现timepicker

在github上看到的练习,看了遍代码后,按自己的思路再修改了一下。
先放原址:https://github.com/graysheeep/vue-material-timepicker。
自己做的在线demo:http://jsbin.com/dumace/2/edit?html,js,output

主要用到的还是Vue的基本知识而已,不过要想到的细节很多。
先放效果,点击上框,显示timepicker。而且可以根据点击的是时还是分来改变圆盘的数字。

这里我用了两个组件,<time-box>和<time-picker>,这里的时和分的数值我挂在了根实例中,因为两个组件都需要这两个值,所以想了想我决定还是挂在根实例,通过动态绑定到组件中。HTML见在线demo。

根组件

var app = new Vue({
 el: "#app",
 data: {
  minutes: 15,
  hour: 8,
  showTimePicker: false,
  current: 0  //0为时、1为分
 },
 created: function(){
  this.$on("closeTimePicker",function() {  //监听关闭time-picker
   this.showTimePicker = false;
  }),
  this.$on("openTimePicker",function() {
   this.showTimePicker = true;
  }),
  this.$on("getTime",function(h,m) {   //获取time-picker返回的点击后的数值,然后动态改变
   this.minutes = m;
   this.hour = h;
  })
 }
})

<time-box>组件

点击时、分的时候,要“通知”根实例点击的是什么,下面的时钟才能显示相应的数字。改变父组件的属性,有两种办法,一是直接修改父组件属性;二是通过自定义事件。

Vue.component('time-box',{
 template:'\
  <div class="timeBox" @click="openTime">\
   <span @click="changeCurrent(\'h\')">{{hour}}</span>\
   <span> : </span>\
   <span @click="changeCurrent(\'m\')">{{minutes}}<span/>\
  </div>',
 props: ['hour','minutes'],
 methods: {
  openTime: function() {
   app.$emit("openTimePicker");
  },
  changeCurrent: function(type) {
   if(type == 'h' ){
    app.current = 0;
   } else {
    app.current = 1;
   }
  }
 }
});

<time-picker>组件

这里最需要注意的就是单向数据流。时分是通过props传进来的,刚开始我直接操作this.hour,然后控制台警告。看到警告才想起看过的知识,这样很容易误改父组件的信息。所以啊,有些东西得实践才行,不能只看不敲。这里我定义一个局部 data 属性,并将 prop 的初始值作为局部数据的初始值。知识点:https://cn.vuejs.org/v2/guide/components.html#单向数据流

props: ['h','m','mode'],
data: function() {
 return {
  current: this.mode,
  hour: this.h,
  minutes: this.m
 }
},

正常情况下,如果时分不够两位数就要自动添加0,实现很简单的。刚开始直接判断是否小于10就添加。但是,“08”是小于10的,所以又自动添加0了。但是我觉得这里写得不好,还有改进的空间的。

//时分保证是两位数
fixHour: function() {
 return (this.hour < 10 && this.hour.toString().indexOf(0) !== 0) ? "0" + this.hour : this.hour
}
fixMinutes: function() {
 return (this.minutes < 10 && this.minutes.toString().indexOf(0) !== 0) ? "0" + this.minutes : this.minutes
},

再说说template里面的事吧。点击timepicker里面的时分改变组件的的current属性和透明度。这里显示数据就需要用到fixHour和fixMinutes了。

<div class="showtime">
 <span @click="current = 0" :style="{opacity: current == 0 ? 1 : 0.7}">{{fixHour(hour)}}</span>
 <span>:</span>
 <span @click="current = 1" :style="{opacity: current == 1 ? 1 : 0.7}">{{fixMinutes(minutes)}}</span>
</div>

圆盘里的内容就靠v-for了。先定义好12个位置,然后遍历每个位置。里面的针就通过CSS3的旋转啦。一共360度,12个格,一小时60分钟,这么简单的数字知识就不继续说下去了,下面的乘法我相信各位是看得懂的。这里注意的是60,我们钟表没有60只有0啊,所以 ((5 * i) % 60 || “00”)。这里写得很有技巧。60%60是0。然后是||和&&的问题了(推荐两本书《你不知道的JavaScript》上中卷,内容跟《高级程序设计JS》也不怎么重复,值得看)。0强转为false,然后||就返回第二个操作数的值。

<template>
 <div class="hourpicker">
   <div class="selector" :style="selectorRotateAngle()"></div>
   <span class="hourtxt" v-for="i in 12" :style="getHourStyle(i%12)" @click="current === 0 ? hour = i : minutes = ((5 * i) % 60 || \'00\')">{{current === 0 ? i : ((5 * i) % 60 || "00")}}</span>\
 </div>
</template>

methods: {
 //分时针的样式
 selectorRotateAngle: function(i) {
  if(this.current === 0) {
   return {
    transform: 'rotateZ('+(this.hour * 30)+'deg)'
   }
  } else {
   return {
    transform: 'rotateZ('+(this.minutes * 6)+'deg)'
   }
  }
 },
 //12格样式
 getHourStyle: function(i) {
  var hasSelected = (this.current === 0 && this.hour % 12 === i)
    || (this.current === 1 && this.minutes % 60 == (i * 5));  //判断到底是哪个数值被选中
  var styleObj = {
   transform: 'translate(' + positions[i][0] + "px, " + positions[i][1] + "px)",
   background: hasSelected ? 'rgb(0, 188, 212)' : 'rgba(255, 255, 255, 0)',
   color: !hasSelected ? '#2c3e50' : '#FFF'
  }
  return styleObj;
 }
}


最后就是把选好的数值传回给父组件啦。

//关闭timepicker
closePicker: function() {
 app.$emit('closeTimePicker');
},
 //获取时间
getTime: function() {
 app.$emit('getTime',this.fixHour(this.hour),this.fixMinutes(this.minutes));
 app.$emit('closeTimePicker');
}

v-ifv-show

v-show只是改变每次的display,而v-if如果为true才渲染到页面,所以每次隐藏显示都重新渲染一遍。我觉得。。。如果实际中,经常要开开关关的就用v-show就好了,但是用来v-show我发现不能根据选中的是时还是分来展现数值,很奇怪,v-if就可以。刚开始觉得是初始化问题,但是,既然hour和minute能根据props传下来再data转化,为啥mode就不行呢?没想明白。

在线demo:http://jsbin.com/dumace/2/edit?html,js,output

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


# Vue  # timepicker  # Bootstrap时间选择器datetimepicker和daterangepicker使用实例解析  # angularjs封装bootstrap时间插件datetimepicker  # bootstrap datetimepicker日期插件使用方法  # bootstrap-datetimepicker实现只显示到日期的方法  # 仿Angular Bootstrap TimePicker创建分钟数-秒数的输入控件  # Bootstrap3 datetimepicker控件使用实例  # 基于bootstrap-datetimepicker.js不支持IE8的快速解决方法  # bootstrap datetimepicker日期插件超详细使用方法介绍  # AngularJs中Bootstrap3 datetimepicker使用实例  # 刚开始  # 的是  # 我觉得  # 挂在  # 写得  # 自己的  # 两位数  # 也不  # 是时  # 看了  # 就不  # 一是  # 遍历  # 很有  # 很容易  # 一遍  # 这两个  # 用了  # 要想  # 第二个 


相关文章: 北京网站制作公司哪家好一点,北京租房网站有哪些?  建站之星CMS建站配置指南:模板选择与SEO优化技巧  子杰智能建站系统|零代码开发与AI生成SEO优化指南  微信小程序 input输入框控件详解及实例(多种示例)  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  建站主机与虚拟主机有何区别?如何选择最优方案?  测试制作网站有哪些,测试性取向的权威测试或者网站?  如何在万网主机上快速搭建网站?  如何生成腾讯云建站专用兑换码?  如何在云主机快速搭建网站站点?  如何通过远程VPS快速搭建个人网站?  股票网站制作软件,网上股票怎么开户?  如何快速查询域名建站关键信息?  开封网站制作公司,网络用语开封是什么意思?  PHP正则匹配日期和时间(时间戳转换)的实例代码  高防服务器如何保障网站安全无虞?  如何快速搭建FTP站点实现文件共享?  南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?  如何做静态网页,sublimetext3.0制作静态网页?  如何正确下载安装西数主机建站助手?  如何通过免费商城建站系统源码自定义网站主题与功能?  如何在万网开始建站?分步指南解析  深圳网站制作的公司有哪些,dido官方网站?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  北京网站制作网页,网站升级改版需要多久?  小型网站建站如何选择虚拟主机?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  如何自定义建站之星模板颜色并下载新样式?  魔毅自助建站系统:模板定制与SEO优化一键生成指南  建站之星伪静态规则如何正确配置?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  网站制作知乎推荐,想做自己的网站用什么工具比较好?  ui设计制作网站有哪些,手机UI设计网址吗?  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  济南网站制作的价格,历城一职专官方网站?  如何高效完成自助建站业务培训?  免费网站制作appp,免费制作app哪个平台好?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  高端云建站费用究竟需要多少预算?  盐城做公司网站,江苏电子版退休证办理流程?  高端建站三要素:定制模板、企业官网与响应式设计优化  贸易公司网站制作流程,出口贸易网站设计怎么做?  简历在线制作网站免费,免费下载个人简历的网站是哪些?  建站主机与服务器功能差异如何区分?  建站之星代理费用多少?最新价格详情介绍  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  如何快速生成可下载的建站源码工具?  中山网站制作网页,中山新生登记系统登记流程?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作? 

您的项目需求

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