在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-if和v-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使用实例
# 刚开始
# 的是
# 我觉得
# 挂在
# 写得
# 自己的
# 两位数
# 也不
# 是时
# 看了
# 就不
# 一是
# 遍历
# 很有
# 很容易
# 一遍
# 这两个
# 用了
# 要想
# 第二个
相关文章:
c# 在高并发下使用反射发射(Reflection.Emit)的性能
详解jQuery停止动画——stop()方法的使用
金*站制作公司有哪些,金华教育集团官网?
css网站制作参考文献有哪些,易聊怎么注册?
建站ABC备案流程中有哪些关键注意事项?
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
如何通过智能用户系统一键生成高效建站方案?
定制建站策划方案_专业建站与网站建设方案一站式指南
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
小建面朝正北,A点实际方位是否存在偏差?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
如何通过虚拟主机快速完成网站搭建?
建站之星如何实现五合一智能建站与营销推广?
专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?
建站主机是什么?如何选择适合的建站主机?
免费视频制作网站,更新又快又好的免费电影网站?
娃派WAP自助建站:免费模板+移动优化,快速打造专业网站
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
全景视频制作网站有哪些,全景图怎么做成网页?
建站主机如何选?高性价比方案全解析
如何通过云梦建站系统实现SEO快速优化?
,如何利用word制作宣传手册?
如何零基础开发自助建站系统?完整教程解析
零服务器AI建站解决方案:快速部署与云端平台低成本实践
建站主机选购指南:核心配置优化与品牌推荐方案
建站之星展会模版如何一键下载生成?
建站之星24小时客服电话如何获取?
开源网站制作软件,开源网站什么意思?
如何通过FTP空间快速搭建安全高效网站?
建站之星如何保障用户数据免受黑客入侵?
如何用PHP快速搭建CMS系统?
建站之星如何快速解决建站难题?
济南网站制作的价格,历城一职专官方网站?
焦点电影公司作品,电影焦点结局是什么?
广德云建站网站建设方案与建站流程优化指南
如何用西部建站助手快速创建专业网站?
如何在阿里云部署织梦网站?
专业公司网站制作公司,用什么语言做企业网站比较好?
道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
用v-html解决Vue.js渲染中html标签不被解析的问题
南宁网站建设制作定制,南宁网站建设可以定制吗?
如何配置支付宝与微信支付功能?
怀化网站制作公司,怀化新生儿上户网上办理流程?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
香港服务器选型指南:免备案配置与高效建站方案解析
盐城做公司网站,江苏电子版退休证办理流程?
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
*请认真填写需求信息,我们会在24小时内与您取得联系。