vue实现日历备忘录功能

用vue写了个日历备忘录的功能,省略了备忘录的增删改查功能。

直接上代码

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>备忘录</title>
 <style type="text/css">
  #box{
   width: 469px;
  }
  /*日历*/
   *{
    padding: 0;
    margin: 0;
   }
   li{
    list-style: none;
   }
   #calendar{
    width:380px;
    margin: 40px auto 0;
    padding-bottom: 30px;
    border-bottom: 1px solid #eee;
   }
   .pickDay{
    margin: 0 auto;
    width: 100px;
    height: 65px;
    text-align: center;
   }
   .pickDay span{
    font-size: 12px;
    color: #989898;
   }
   .pickDay span:first-of-type{
    font-size: 72px;
    color: #789AF7;
   }
   .month {
    width: 100%;
   }
   .month ul {
    margin: 29px 0 25px;
    display: flex;
    justify-content: center;
   }
   .year-month {
    width: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
   }
   .choose-year {
    font-size: 14px;
    color: #989898;
   }
   .choose-month {
    text-align: center;
    color: #989898;
    font-size: 14px;
   }
   .arrow {
    width: 28px;
    height: 28px;
    text-align: center;
   }

   .arrow:hover {
    background: rgba(100, 2, 12, 0.1);
    cursor: pointer;
   }

   .month ul li {
    color: #789AF7;
    font-size: 20px;
   }

   .weekdays {
    width: 270px;
    margin: 0 auto 7.5px;
    display: flex;
    flex-wrap: wrap;
    color: #808080;
    justify-content: space-around;
   }

   .weekdays li {
    display: inline-block;
    font-size: 16px;
    color: #808080;
    width: 26px;
    text-align: center;
   }

   .days {
    width: 270px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    background: #FFFFFF;
   }

   .days li {
    position: relative;
    display: inline-block;
    width: 14.2%;
    text-align: center;
    padding-bottom: 7.5px;
    padding-top: 7.5px;
    color: #999;
    cursor: pointer;
   }
   .days .momo_mark{
    position: absolute;
    right: 0;
    top: 10px;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #7699F8;
   }
   .days li span{
    font-size: 16px;
   }
   .days li .active {
    color: #789AF7;
   }
   .days li .other-month {
    padding: 5px;
    color: #E6E6E6;
   }
   .days li:hover{
    color: #789AF7;
   }
   .days li:hover .other-month{
    color: #789AF7;
   }

  /*备忘录*/
   #memo{
    width: 400px;
    margin: 30px 0 0 20px;
   }
   #memo h4{
    text-indent: 20px;
    height: 20px;
    line-height: 20px;
    font-size: 14px;
    color: #7699F8;
   }
   .memo_list li{
    margin-top: 12px;
   }
   .memo_list .memo_list_s{
    width: 399px; 

   }
   .memo_list .memo_list_s:hover{
    background: #EEE;
   }
   .memo_list .memo_list_s:hover .circle{
    background: #F84848;
   }

   .memo_list .memo_list_s:hover #edit_memo{
    background: url(../assets/edit_active.png) no-repeat;
   }
   .memo_list .memo_list_s:hover #del_memo{
    background: url(../assets/del_active.png) no-repeat;
   }
   .circle{
    display: inline-block;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #7699F8;
    vertical-align: top;
    margin: 12px 5px 0px 9px;
   }
   .memo_list_mont{
    display: inline-block;
    width: 323px;
    min-height: 30px;
    line-height: 30px;
    font-size: 14px;
    color: #666666;
   }
   .memo_operate{
    display: inline-block;
    vertical-align: top;
    font-size: 0;
    padding-top: 9px;
   }
   .memo_operate button{
    width: 12px;
    height: 12px;
    margin-right: 10px;
    background: #fff;
    border: none;
   }
   #addMemo{
    width: 96px;
    height: 28px;
    line-height: 28px;
    color: #789BF8;
    background: #fff;
    border: 1px solid #789BF8;
    border-radius: 2px;
    margin: 25px 0 0 20px;
   }
   .memo_cont{
    width: 310px;
    background: #7699F8;
    border-radius: 2px;
    margin-left: 20px;
    margin-top: 15px;
    padding: 37px 30px 24px 30px;
   }
   .memo_edit{
    width: 100%;
    min-height: 140px;
    line-height: 28px;
    color: #fff;
    font-size: 14px;
    background: url(../assets/bgborder.png) repeat-y;
    outline: none;
    border: none;
    resize:none;
   }
   .edit_operate{
    padding-top: 20px;
    display: flex;
    justify-content: flex-end;
   }
   .edit_operate button{
    width: 20px;
    height: 20px;
    margin-left: 16px;

   }
   #cancel_edit{
    background: url(../assets/error.png) center center no-repeat;
   }
   #save_edit{
    background: url(../assets/right.png) center center no-repeat;
   }

  /*动画*/
   .fade-enter-active, .fade-leave-active {
    transition: all 0.5s ease-in;
   }
   .fade-enter, .fade-leave-to{
    opacity: 0;
   }
 </style>
</head>
<body>
 <div id="box">
  <div id="calendar" v-if="pickDay != null">
   <div class="pickDay">
    <span>{{pickDay}}</span><span>日</span>
   </div>
   <!-- 年份 月份 -->
   <div class="month">
    <ul>
     <li class="arrow" @click="pickPre(currentYear,currentMonth)">❮</li>
     <li class="year-month" @click="pickYear(currentYear,currentMonth)">
     <span class="choose-year">{{ currentYear }}</span>
     <span class="choose-month"> - {{ currentMonth }}</span>
     </li>
     <li class="arrow" @click="pickNext(currentYear,currentMonth)">❯</li>
    </ul>
   </div>
   <!-- 星期 -->
   <ul class="weekdays">
    <li>MO</li>
    <li>TU</li>
    <li>WE</li>
    <li>TH</li>
    <li>FR</li>
    <li style="color:red">SA</li>
    <li style="color:red">SU</li>
   </ul>
   <!-- 日期 -->
   <ul class="days">
    <li @click="pick(day.day)" v-for="day in days">
     <!--本月-->
     <span class="momo_mark" v-if="day.memo_type"></span>
     <span v-if="day.day.getMonth()+1 != currentMonth" class="other-month">{{ day.day.getDate() }}</span>
     <span v-else>
      <!--今天-->
      <span v-if="day.day.getFullYear() == new Date().getFullYear() && day.day.getMonth() == new Date().getMonth() && day.day.getDate() == new Date().getDate()" class="active">{{ day.day.getDate() }}</span>
      <span v-else>{{ day.day.getDate() }}</span>
     </span>
    </li>
   </ul>
  </div>
  <div id="memo">
   <h4>备忘录</h4>
   <ul class="memo_list" v-if="currentMemo">
    <li v-for="(memo,index) in currentMemo" :key="index">
     <div class="memo_list_s">
      <span class="circle"></span>
      <div class="memo_list_mont">{{memo.cont}}</div>
     </div>
    </li>
   </ul>
  </div>
 </div>
</body>
 <script src="https://cdn.bootcss.com/vue/2.5.11/vue.js"></script>
 <script type="text/javascript">
  var vm = new Vue({
   el : "#box",
   data : {
    currentDay: 1,
    currentMonth: 1,
    currentYear: 1970,
    currentWeek: 1,
    days: [],
    pickDay : null,
    currentMemo : null,
    memo_list :["2018-05-11","2018-05-31"]//时间格式必须为xxxx-xx-xx;
   },
   created: function() {
    this.initCalendar(null);
    },
   methods:{
    initCalendar: function(cur){
     if (cur) {
      var date = new Date(cur);
     } else {
      var date = new Date();
      this.pickDay = date.getDate();
     }
     this.currentYear = date.getFullYear();
     this.currentMonth = date.getMonth() + 1;
     var str = this.formatDate(this.currentYear , this.currentMonth, 1);
     this.currentWeek = new Date(str).getDay() == 0 ? 7 : new Date(str).getDay();

     this.days.length = 0;//初始化数组
     for (var i = this.currentWeek - 1; i >= 0; i--) {
      var d = new Date(str);
      var memo_type = false;
      d.setDate(d.getDate() - i);
      for (var j = 0; j < this.memo_list.length; j++) {
       var memoTime = new Date(this.memo_list[j]).getTime();
       if( d.getTime() == memoTime){
        memo_type = true;
       }
      }
      this.days.push({day:d,memo_type:memo_type});
     }
     for (var i = 1; i <= 35 - this.currentWeek; i++){
      var d = new Date(str);
      d.setDate(d.getDate() + i);
      var memo_type = false;
      for (var j = 0; j < this.memo_list.length; j++) {
       var memoTime = new Date(this.memo_list[j]).getTime()
       if( d.getTime() == memoTime){
        memo_type = true;
       }
      }
      this.days.push({day:d,memo_type:memo_type});
     }
    },
    pick: function(date){
     this.pickDay = date.getDate();
     this.initCalendar(this.formatDate(date.getFullYear() , date.getMonth() + 1, 1));
     var curPickDay = this.formatDate(date.getFullYear() , date.getMonth() + 1, date.getDate())
     // 数据发送请求拿回即可,这里我就写死了,随便写两个样例
     if(curPickDay == "2018-05-11"){
      this.currentMemo = [{
       cont :"setDate() 方法用于设置一个月的某一天。该方法什么都不返回"
      },{
       cont :"getTime() 方法可返回距 1970 年 1 月 1 日之间的毫秒数。"
      }]
     }else if(curPickDay == "2018-05-31"){
      this.currentMemo = [{
       cont :"getDay() 方法可返回表示星期的某一天的数字。返回值是 0(周日) 到 6(周六) 之间的一个整数"
      },{
       cont :"setDate(0); 上月最后一天;setDate(-1); 上月倒数第二天;setDate(dx) 参数dx为 上月最后一天的前后dx天"
      }]
     }else{
      this.currentMemo= null;
     }
    },
    pickPre: function(year, month){
     // setDate(0); 上月最后一天
     // setDate(-1); 上月倒数第二天
     // setDate(dx) 参数dx为 上月最后一天的前后dx天
     var d = new Date(this.formatDate(year , month , 1));
     d.setDate(0);
     this.initCalendar(this.formatDate(d.getFullYear(),d.getMonth() + 1,1));
    },
    pickNext: function(year, month){
     var d = new Date(this.formatDate(year , month , 1));
     d.setDate(35);
     this.initCalendar(this.formatDate(d.getFullYear(),d.getMonth() + 1,1));
    },
    // 返回 类似 2016-01-02 格式的字符串
    formatDate: function(year,month,day){
     var y = year;
     var m = month;
     if(m<10) m = "0" + m;
     var d = day;
     if(d<10) d = "0" + d;
     return y+"-"+m+"-"+d
    }
   }
  })
 </script>
</html>

欢迎大家提意见,提BUG

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

(0)

相关推荐

  • Vuex2.0+Vue2.0构建备忘录应用实践

    一.介绍Vuex Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化,适合于构建中大型单页应用. 1.什么是状态管理模式? 看个简单的例子: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content=&q

  • vue.js实现备忘录功能的方法

    这个vue实现备忘录的功能demo是K在github上找到的,K觉得这是一个用来对vue.js入门的一个非常简单的demo,所以拿在这里共享一下. (尊重他人劳动成果,从小事做起~  demo原github地址:https://github.com/vuejs/vue) 一.实现效果 二.代码展示 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>备忘录&l

  • Vue.js实现备忘录功能

    本文实例为大家分享了Vue.js实现备忘录的具体代码,供大家参考,具体内容如下 效果展示: html代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <!-- 移动设备设置 --> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-

  • vue实现日历备忘录功能

    用vue写了个日历备忘录的功能,省略了备忘录的增删改查功能. 直接上代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>备忘录</title> <style type="text/css"> #box{ width: 469px; } /*日历*/ *{ padding:

  • VUE实现日历组件功能

    哈哈, 就在昨天笔者刚刚在Github 上发布了一个基于VUE的日历组件.过去做日历都是需要引用 jquery moment 引用 fullCalendar.js 的.几者加起来体积庞大不说,也并不是很好使用在vue这种数据驱动的项目里.所以笔者经过一周的拍脑袋,做了一个十分简陋的版本. 简介 目前只支持月视图,该组件是 .vue 文件的形式.所以,大家在使用的时候 是需要node的咯~~~ 安装 npm install vue-fullcalendar DEMO 针对这个组件, 本人做了一个十

  • vue实现打卡功能

    本文实例为大家分享了vue实现打卡功能的具体代码,供大家参考,具体内容如下 记录使用vue实现移动端日历打卡样式 templatecompareToNow:与当前时间比较-1:小于当前时间0:今天1:大于当前时间 <!-- @click="todo" 实现打卡功能 --> <div v-if="compareToNow(item) === 1" @click="todo">{{ item.date }}</div&g

  • Vue自定义日历小控件使用方法详解

    本文实例为大家分享了Vue自定义日历小控件的具体代码,供大家参考,具体内容如下 废话少说,先上效果图: 可以在效果图中看到,选择不同的月份的时候当月天数与星期几都是一一对应,非当月天数则是灰色显示,一目了然. 并且此日历控件支持自动确定当前时间,每次打开默认显示的就是最新的月份,用来做签到打卡的功能比较合适. 由于使用的是原生div进行制作,自定义功能非常强,可以自由的更换样式.背景.颜色.大小等等. 在与数据库的时候可以从数据库获得时间信息并填充到控件中,图中的色块就可以看出. 该控件使用了V

  • Vue实现typeahead组件功能(非常靠谱)

     前言 之前那个typeahead写的太早,不满足当前的业务需求. 而且有些瑕疵,还有也不方便传入数据和响应数据.. 于是就推倒了重来,写了个V2的版本 看图,多了一些细节的考虑;精简了实现的逻辑代码 效果图 实现的功能 1: 鼠标点击下拉框之外的区域关闭下拉框 2: 支持键盘上下键选择,支持鼠标选择 3: 支持列表过滤搜索 4: 支持外部传入列表JSON格式的映射 5: 支持placeholder的传入 6: 选中对象的响应(.sync vue2.3的组件通讯的语法糖) 7: 箭头icon的映

  • Vue 仿百度搜索功能实现代码

    无上下选择 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>jsonp</title> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, us

  • Vue实现选择城市功能

    查看完整的代码请到   我的github地址  https://github.com/qianyinghuanmie/vue2.0-demos 一.结果展示 二.前期准备: 1.引入汉字转拼音的插件,利用NPM安装 代码指令为 npm install pinyin --save ,详细步骤请到pinyin 2.引入vue-resource,调用json文件,可以参考目录中的city.json,有条件的也可以自己去扒 三. 分析 所实现的功能点: 1.获取json数据展示城市列表 . 2.侧边字母

  • C# 日历类功能的实例代码

    C# 日历类的实现代码,具体如下所示: using System; namespace DotNet.Utilities { /// <summary> /// 农历属性 /// </summary> public class CNDate { /// <summary> /// 农历年(整型) /// </summary> public int cnIntYear = 0; /// <summary> /// 农历月份(整型) /// <

随机推荐