zoukankan      html  css  js  c++  java
  • vue 日历签到

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="https://cdn.bootcss.com/vue/2.4.4/vue.min.js"></script>
    
        <style>
            * {
                box-sizing: border-box;
            }
    
            ul {
                list-style-type: none;
            }
    
            body {
                font-family: Verdana, sans-serif;
                background: #E8F0F3;
            }
            #calendar{
                width:80%;
                margin: 0 auto;
                box-shadow: 0 2px 2px 0 rgba(0,0,0,0.14), 0 3px 1px -2px rgba(0,0,0,0.1), 0 1px 5px 0 rgba(0,0,0,0.12);
            }
            .month {
                width: 100%;
                background: #00B8EC;
            }
    
            .month ul {
                margin: 0;
                padding: 0;
                display: flex;
                justify-content: space-between;
            }
    
            .year-month {
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: space-around;
            }
    
            .year-month:hover {
                background: rgba(150, 2, 12, 0.1);
            }
    
            .choose-year {
                padding-left: 20px;
                padding-right: 20px;
            }
    
            .choose-month {
                text-align: center;
                font-size: 1.5rem;
            }
    
            .arrow {
                padding: 30px;
            }
    
            .arrow:hover {
                background: rgba(100, 2, 12, 0.1);
            }
    
            .month ul li {
                color: white;
                font-size: 20px;
                text-transform: uppercase;
                letter-spacing: 3px;
            }
    
            .weekdays {
                margin: 0;
                padding: 10px 0;
                background-color: #00B8EC;
                display: flex;
                flex-wrap: wrap;
                color: #FFFFFF;
                justify-content: space-around;
            }
    
            .weekdays li {
                display: inline-block;
                width: 13.6%;
                text-align: center;
            }
    
            .days {
                padding: 0;
                background: #FFFFFF;
                margin: 0;
                display: flex;
                flex-wrap: wrap;
                justify-content: space-around;
            }
    
            .days li {
                list-style-type: none;
                display: inline-block;
                width: 14.2%;
                height: 70px;
                text-align: center;
                padding-bottom: 15px;
                padding-top: 15px;
                font-size: 1rem;
                color: #000;
            }
    
            .days li .active {
                padding: 6px 10px;
                border-radius: 50%;
                background: #00B8EC;
                color: #fff;
            }
    
            .days li .other-month {
                padding: 5px;
                color: gainsboro;
            }
    
            .days li:hover {
                background: #e1e1e1;
            }
        </style>
    </head>
    <body>
    <div id="calendar">
        <!-- 年份 月份 -->
        <div class="month">
            <ul>
                <!--点击会触发pickpre函数,重新刷新当前日期 @click(vue v-on:click缩写) -->
                <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></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li style="color:red"></li>
            <li style="color:red"></li>
        </ul>
        <!-- 日期 -->
        <ul class="days">
            <!-- 核心 v-for循环 每一次循环用<li>标签创建一天 -->
            <li  v-for="dayobject in days">
                <!--本月-->
                <!--如果不是本月  改变类名加灰色-->
    
                <span v-if="dayobject.day.getMonth()+1 != currentMonth" class="other-month">{{ dayobject.day.getDate() }}</span>
    
                <!--如果是本月  还需要判断是不是这一天-->
                <span v-else>
              <!--今天  同年同月同日-->
                    <span v-if=" dayobject.isSign===true" class="active">{{ dayobject.day.getDate() }}</span>
                    <span v-else>{{ dayobject.day.getDate() }}</span>
                </span>
    
            </li>
        </ul>
    </div>
    
    
    
    <script>
        var myVue=new Vue({
            el: '#calendar',
            data: {
                currentDay: 1,
                currentMonth: 1,
                currentYear: 1970,
                currentWeek: 1,
                days: [],
                arrDate: [10,15]
            },
            created: function() {  //在vue初始化时调用
                this.initData(null);
            },
            methods: {
                initData: function(cur) {
                    var leftcount=0; //存放剩余数量
                    var date;
                    if (cur) {
                      console.log(cur)
                        date = new Date(cur);
                    } else {
                        var now=new Date();
                        var d = new Date(this.formatDate(now.getFullYear() , now.getMonth() , 1));
                        d.setDate(42);
                        date = new Date(this.formatDate(d.getFullYear(),d.getMonth() + 1,1));
                    }
                    this.currentDay = date.getDate();
                    this.currentYear = date.getFullYear();
                    this.currentMonth = date.getMonth() + 1;
    
                    this.currentWeek = date.getDay(); // 1...6,0
                    if (this.currentWeek == 0) {
                        this.currentWeek = 7;
                    }
                    var str = this.formatDate(this.currentYear , this.currentMonth, this.currentDay);
                    this.days.length = 0;
                    // 今天是周日,放在第一行第7个位置,前面6个
                    //初始化本周
                    for (var i = this.currentWeek - 1; i >= 0; i--) {
                        var d = new Date(str);
                        d.setDate(d.getDate() - i);
                        var dayobject={}; //用一个对象包装Date对象  以便为以后预定功能添加属性
                        dayobject.day=d;
                        this.days.push(dayobject);//将日期放入data 中的days数组 供页面渲染使用
                    }
                    //其他周
                    for (var i = 1; i <= 42 - this.currentWeek; i++) {
                        var d = new Date(str);
                        d.setDate(d.getDate() + i);
                        var dayobject={};
                        // dayobject.day=d;
                        dayobject = {day: d,isSign: this.isVerDate(d.getDate())}
                        this.days.push(dayobject);
                    }
                },
                isVerDate (v) {
                    return this.arrDate.includes(v)
                },
                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.initData(this.formatDate(d.getFullYear(),d.getMonth() + 1,1));
                },
                pickNext: function(year, month) {
                    var d = new Date(this.formatDate(year , month , 1));
                    d.setDate(42);
                    this.initData(this.formatDate(d.getFullYear(),d.getMonth() + 1,1));
                },
                pickYear: function(year, month) {
                    alert(year + "," + month);
                },
    
                // 返回 类似 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>
    </body>
    </html>

    个人博客

  • 相关阅读:
    MySQL学习笔记(六):索引
    正则表达式基础知识,持续更新…
    js改变盒子大小(上下左右)分析
    表单自定义样式
    js拖拽分析
    javascript右键菜单分析
    简要分析javascript的选项卡和轮播图
    表单联动的总结
    浅显总结ASCII Unicode UTF-8的区别
    瀑布流知识的延伸
  • 原文地址:https://www.cnblogs.com/vhen/p/7699381.html
Copyright © 2011-2022 走看看