实现一个日期组件,如图:
components.js代码如下:
Vue.component('sc-calendar',{ template:'<div class="scCalendar">' + '<div class="calendar_header">' + '<div class="prev" @click="prevMonth"> < </div>' + '<span class="text_year">{{currentYear}}年</span>' + '<span class="text_month">{{currentMonth}}月</span>' + '<div class="next" @click="nextMonth"> > </div>' + '</div>' + '<div class="calendar_content">' + '<ul class="week">' + '<li v-for="item in weeks">{{item}}</li>' + '</ul>' + '<ul class="day">' + '<li v-for="item in dayList" :class="{marginRight0:item.marginRight0}">{{item.text}}</li>' + '</ul>' + '</div>' + '</div>', data:function(){ return { weeks: ['日', '一', '二', '三', '四', '五', '六'], dayList:[], currentYear:'', currentMonth: '' } }, created:function(){ var date=new Date; this.currentYear = date.getFullYear(); this.currentMonth = date.getMonth()+1; this.calDay(this.currentYear, this.currentMonth); }, methods:{ //计算指定月份的天数 calDay:function(year,month){ var oDate = new Date(); //setFullYear(year,month,day) 方法用于设置年份,返回调整过的日期的毫秒表示。 oDate.setFullYear(year, month-1,1); oDate.setDate(1);//设置一个月中的第一天 var oNow = oDate.getDay();//当前月的第一天是星期几 var dayNum = 0; //指定月份的天数 if(month==1 || month==3 || month==5 || month==7 || month==8 || month==10 || month==12){ dayNum = 31; }else if(month==4 || month==6 || month==9 || month==11){ dayNum = 30; }else if(month==2&&this.isLeaYear(year)){ dayNum = 29; }else{ dayNum = 28; } var SumDayLiNum = 0;//总共的格子数 var lastNum = (dayNum-(7-oNow))%7; //最后剩余的数 lastNum = lastNum == 0"htmlcode">html { font-family: '微软雅黑'; } body, div, span, img, ul, li, p { margin: 0; padding: 0; } ul, li { list-style: none; } .commonprev { width: 0.46666667rem; height: 0.93333333rem; color: #ffffff; position: absolute; display: inline-block; } .commonyear { width: 5.46666667rem; height: 1.6rem; font-size: 1rem; color: #ffffff; position: absolute; } .scCalendar { width: 25rem; height: 21.66666667rem; background: #005498; background-size: 100%; } .scCalendar .calendar_header { height: 2.93333333rem; width: 100%; position: relative; line-height: 2.93333333rem; } .scCalendar .calendar_header .prev { width: 0.46666667rem; height: 0.93333333rem; color: #ffffff; position: absolute; display: inline-block; left: 2.76666667rem; } .scCalendar .calendar_header .next { width: 0.46666667rem; height: 0.93333333rem; color: #ffffff; position: absolute; display: inline-block; right: 2.76666667rem; } .scCalendar .calendar_header .text_year { width: 5.46666667rem; height: 1.6rem; font-size: 1rem; color: #ffffff; position: absolute; left: 9.76666667rem; } .scCalendar .calendar_header .text_month { width: 5.46666667rem; height: 1.6rem; font-size: 1rem; color: #ffffff; position: absolute; left: 13.1rem; } .scCalendar .calendar_content { padding: 0 1rem; } .scCalendar .calendar_content li { width: 2rem; height: 2rem; line-height: 2rem; margin-right: 1.5rem; text-align: center; margin-bottom: 0.66666667rem; float: left; color: white; font-size: 0.93333333rem; } .scCalendar .calendar_content .week li:nth-of-type(7) { margin-right: 0; } .scCalendar .calendar_content .day .marginRight0 { margin-right: 0; }index.html代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <link rel="stylesheet" href="./ccal.css" rel="external nofollow" > <script> var pixRatio = 1/window.devicePixelRatio; //像素比 var html = document.documentElement; document.write('<meta name="viewport" content="width=device-width,user-scalable=no,initial-scale='+ pixRatio +',minimum-scale='+ pixRatio +',maximum-scale='+ pixRatio +'">'); html.style.fontSize = html.clientWidth/25 + 'px'; </script> <script src="/UploadFiles/2021-04-02/vue.js">总结
以上所述是小编给大家介绍的vue实现自定义日期组件功能的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 第五街的士高《印度激情版》3CD [WAV+CUE][2.4G]
- 三国志8重制版哪个武将智力高 三国志8重制版智力武将排行一览
- 三国志8重制版哪个武将好 三国志8重制版武将排行一览
- 三国志8重制版武将图像怎么保存 三国志8重制版武将图像设置方法
- 何方.1990-我不是那种人【林杰唱片】【WAV+CUE】
- 张惠妹.1999-妹力新世纪2CD【丰华】【WAV+CUE】
- 邓丽欣.2006-FANTASY【金牌大风】【WAV+CUE】
- 饭制《黑神话》蜘蛛四妹手办
- 《燕云十六声》回应跑路:年内公测版本完成95%
- 网友发现国内版《双城之战》第二季有删减:亲亲环节没了!
- 邓丽君2024-《漫步人生路》头版限量编号MQA-UHQCD[WAV+CUE]
- SergeProkofievplaysProkofiev[Dutton][FLAC+CUE]
- 永恒英文金曲精选4《TheBestOfEverlastingFavouritesVol.4》[WAV+CUE]
- 群星《国风超有戏 第9期》[320K/MP3][13.63MB]
- 群星《国风超有戏 第9期》[FLAC/分轨][72.56MB]