Vue自定义日历控件的使用是什么样的呢
Admin 2022-09-01 群英技术资讯 582 次浏览
本文实例为大家分享了Vue自定义日历小控件的具体代码,供大家参考,具体内容如下
废话少说,先上效果图:
可以在效果图中看到,选择不同的月份的时候当月天数与星期几都是一一对应,非当月天数则是灰色显示,一目了然。
并且此日历控件支持自动确定当前时间,每次打开默认显示的就是最新的月份,用来做签到打卡的功能比较合适。
由于使用的是原生div进行制作,自定义功能非常强,可以自由的更换样式、背景、颜色、大小等等。
在与数据库的时候可以从数据库获得时间信息并填充到控件中,图中的色块就可以看出。
该控件使用了Vue、CSS、以及最原生的div实现了自定义的样式,不得不说,div在自定义这一块是真的太给力了。
代码如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>日历控件</title> <script src="./vue.js"></script> </head> <style> .writer-upper-right { float: left; width: 333px; height: 300px; border: 2px orange solid; border-radius: 7px; } .calendar-head { width: 100%; height: 15%; border-radius: 7px; } .calendar-body { width: 99.9%; height: 84.9%; border-radius: 7px; border-top: 1px orange solid; } .calendar-head-title { float: left; width: 100px; height: 79%; line-height: 33px; border-radius: 7px; border: 2px orange solid; margin-top: 2px; margin-left: 1px; text-align: center; color: orange; font-size: 21px; } .calendar-head-year { float: left; margin-left: 9px; width: 100px; height: 79%; border-radius: 7px; border: 2px orange solid; margin-top: 2px; color: orange; text-align: center; } .select-calendar-year { float: left; width: 100%; height: 100%; border: none; background: none; color: orange; text-indent: 0.7em; font-size: 20px; } .select-calendar-year:focus { outline: none; } .select-calendar-year:hover { cursor: pointer; } .calendar-body-week { width: 99.8%; height: 32px; margin: 0 auto; border-bottom: 1px orange solid; } .calendar-body-days { width: 99.8%; height: 199px; border-bottom: 1px orange solid; border-top: none; border-radius: 7px; } .calendar-body-info { width: 99.8%; height: 18px; border-radius: 7px; } .weekEveryDay { float: left; width: 40px; height: 23px; margin-left: 5px; margin-top: 4px; border: 1px orange solid; border-radius: 5px; line-height: 23px; text-align: center; font-size: 15px; color: orange; } .monthEveryDay { margin-top: 7px; } .not-now-month { border-color: gray; color: gray; } .now-day-writer { background-color: orange; color: black; } .now-day-not-writer { border-color: gray; background-color: gray; color: black; } .info-if-writer { float: left; width: 60px; height: 16px; margin-left: 5px; margin-top: 1px; } .color-span { float: left; width: 15px; height: 15px; margin-top: 1px; background-color: gray; } .color-info { float: left; width: 40px; height: 15px; margin-top: 1px; margin-left: 5px; line-height: 15px; text-align: left; font-size: 12px; color: gray; } .color-span2 { background-color: orange; } .color-info2 { color: orange; } </style> <body style="background: url('./bg-xk.gif');margin: 100px 100px;"> <div id="app"> <div class="writer-upper-right"> <div class="calendar-head"> <div class="calendar-head-title">日历控件</div> <div class="calendar-head-year"> <label> <select class="select-calendar-year" v-model="calendarYear" @change="SelectCalendarYear"> <option v-for="year in calendarAllYear" :value="year" :key="year">{{year}}年</option> </select> </label> </div> <div class="calendar-head-year"> <label> <select class="select-calendar-year" v-model="calendarMonth" @change="SelectCalendarMonth"> <option v-for="month in calendarAllMonth" :value="month" :key="month">{{month}}月</option> </select> </label> </div> </div> <div class="calendar-body"> <div class="calendar-body-week"> <div class="weekEveryDay">SUN</div> <div class="weekEveryDay">MON</div> <div class="weekEveryDay">TUE</div> <div class="weekEveryDay">WED</div> <div class="weekEveryDay">THU</div> <div class="weekEveryDay">FRI</div> <div class="weekEveryDay">SAT</div> </div> <div class="calendar-body-days"> <div class="weekEveryDay monthEveryDay not-now-month" v-for="day in calendarPrevDays" disabled>{{day}}</div> <div class="weekEveryDay monthEveryDay" v-for="day in calendarNowDays" :class="['weekEveryDay monthEveryDay', {'now-day-writer' : calendarHadWrite.includes(day)}, {'now-day-not-writer' : calendarNotWrite.includes(day)}]" >{{day}}</div> <div class="weekEveryDay monthEveryDay not-now-month" v-for="day in calendarNextDays" disabled>{{day}}</div> </div> <div class="calendar-body-info"> <div class="info-if-writer"> <div class="color-span"></div> <div class="color-info">未更新</div> </div> <div class="info-if-writer"> <div class="color-span color-span2"></div> <div class="color-info color-info2">有更新</div> </div> </div> </div> </div> </div> </body> </html>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
gm是基于node.js的图片处理插件,它封装了图片处理工具GraphicsMagick(GM)和ImageMagick(IM),可使用spawn的方式调用。gm插件不是node默认安装的,需执行“npm install gm -S”进行安装才可使用。
这篇文章主要为大家详细介绍了Vue实现无限加载瀑布流,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章给大家分享的是有关Js实现画廊效果的内容,小编觉得挺实用的,可以用来做图片展示,下文有两种实现效果及代码,感兴趣的朋友可以做个参考,接下来一起跟随小编看看吧。
在JS中,我们经常会遇到原型。字面上的意思会让我们认为,是某个对象的原型,可用来继承。但是其实这样的理解是片面的,下面通过本文来了解原型与原型链的细节,再顺便谈谈继承的几种方式。
vue刷新数据丢失的情况怎样解决?对于这个问题,相信不少朋友都又遇到,也就是进行F5页面刷新的时候,页面的数据会丢失的情况,那么我们有什么解决方法呢?下面我们了解看看。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008