這篇文章主要介紹如何基于Vue實(shí)現(xiàn)timepicker,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
公司主營(yíng)業(yè)務(wù):網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出正藍(lán)免費(fèi)做網(wǎng)站回饋大家。
Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式JavaScript框架,Vue與其它大型框架的區(qū)別是,使用Vue可以自底向上逐層應(yīng)用,其核心庫(kù)只關(guān)注視圖層,方便與第三方庫(kù)和項(xiàng)目整合,且使用Vue可以采用單文件組件和Vue生態(tài)系統(tǒng)支持的庫(kù)開發(fā)復(fù)雜的單頁(yè)應(yīng)用。
主要用到的還是Vue的基本知識(shí)而已,不過要想到的細(xì)節(jié)很多。
先放效果,點(diǎn)擊上框,顯示timepicker。而且可以根據(jù)點(diǎn)擊的是時(shí)還是分來改變圓盤的數(shù)字。
這里我用了兩個(gè)組件,
根組件
var app = new Vue({ el: "#app", data: { minutes: 15, hour: 8, showTimePicker: false, current: 0 //0為時(shí)、1為分 }, created: function(){ this.$on("closeTimePicker",function() { //監(jiān)聽關(guān)閉time-picker this.showTimePicker = false; }), this.$on("openTimePicker",function() { this.showTimePicker = true; }), this.$on("getTime",function(h,m) { //獲取time-picker返回的點(diǎn)擊后的數(shù)值,然后動(dòng)態(tài)改變 this.minutes = m; this.hour = h; }) } })
點(diǎn)擊時(shí)、分的時(shí)候,要“通知”根實(shí)例點(diǎn)擊的是什么,下面的時(shí)鐘才能顯示相應(yīng)的數(shù)字。改變父組件的屬性,有兩種辦法,一是直接修改父組件屬性;二是通過自定義事件。
Vue.component('time-box',{ template:'\\ {{hour}}\ : \ {{minutes}}\', props: ['hour','minutes'], methods: { openTime: function() { app.$emit("openTimePicker"); }, changeCurrent: function(type) { if(type == 'h' ){ app.current = 0; } else { app.current = 1; } } } });
這里最需要注意的就是單向數(shù)據(jù)流。時(shí)分是通過props傳進(jìn)來的,剛開始我直接操作this.hour,然后控制臺(tái)警告。看到警告才想起看過的知識(shí),這樣很容易誤改父組件的信息。所以啊,有些東西得實(shí)踐才行,不能只看不敲。這里我定義一個(gè)局部 data 屬性,并將 prop 的初始值作為局部數(shù)據(jù)的初始值。知識(shí)點(diǎn):https://cn.vuejs.org/v2/guide/components.html#單向數(shù)據(jù)流
props: ['h','m','mode'], data: function() { return { current: this.mode, hour: this.h, minutes: this.m } },
正常情況下,如果時(shí)分不夠兩位數(shù)就要自動(dòng)添加0,實(shí)現(xiàn)很簡(jiǎn)單的。剛開始直接判斷是否小于10就添加。但是,“08”是小于10的,所以又自動(dòng)添加0了。但是我覺得這里寫得不好,還有改進(jìn)的空間的。
//時(shí)分保證是兩位數(shù) 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里面的事吧。點(diǎn)擊timepicker里面的時(shí)分改變組件的的current屬性和透明度。這里顯示數(shù)據(jù)就需要用到fixHour和fixMinutes了。
{{fixHour(hour)}} : {{fixMinutes(minutes)}}
圓盤里的內(nèi)容就靠v-for了。先定義好12個(gè)位置,然后遍歷每個(gè)位置。里面的針就通過CSS3的旋轉(zhuǎn)啦。一共360度,12個(gè)格,一小時(shí)60分鐘,這么簡(jiǎn)單的數(shù)字知識(shí)就不繼續(xù)說下去了,下面的乘法我相信各位是看得懂的。這里注意的是60,我們鐘表沒有60只有0啊,所以 ((5 * i) % 60 || “00”)。這里寫得很有技巧。60%60是0。然后是||和&&的問題了(推薦兩本書《你不知道的JavaScript》上中卷,內(nèi)容跟《高級(jí)程序設(shè)計(jì)JS》也不怎么重復(fù),值得看)。0強(qiáng)轉(zhuǎn)為false,然后||就返回第二個(gè)操作數(shù)的值。
{{current === 0 ? i : ((5 * i) % 60 || "00")}}\methods: { //分時(shí)針的樣式 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)); //判斷到底是哪個(gè)數(shù)值被選中 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; } }
最后就是把選好的數(shù)值傳回給父組件啦。
//關(guān)閉timepicker closePicker: function() { app.$emit('closeTimePicker'); }, //獲取時(shí)間 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才渲染到頁(yè)面,所以每次隱藏顯示都重新渲染一遍。我覺得。。。如果實(shí)際中,經(jīng)常要開開關(guān)關(guān)的就用v-show就好了,但是用來v-show我發(fā)現(xiàn)不能根據(jù)選中的是時(shí)還是分來展現(xiàn)數(shù)值,很奇怪,v-if就可以。剛開始覺得是初始化問題,但是,既然hour和minute能根據(jù)props傳下來再data轉(zhuǎn)化,為啥mode就不行呢?沒想明白。
以上是“如何基于Vue實(shí)現(xiàn)timepicker”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!