移动端calendar日历开发+swiper(支持左右点击,滑屏滚动)

前段时间也做了一个日历项目,不过依赖于jQuery,最近这个项目要求用原生js,便又重新封装了下;

先看效果图:





html:

    <div class="uzai-header">
        <i class="iconfont icon-back" ng-click="backpage();"></i>
        <b>选择日期</b>
    </div>

    <div class="uzai-container">
        <!--日历部分-->
        <div class="uzai-calender">
            <div class="red-bg">

                <div class="switch-btn">
                    <b class="left"></b>
                    <b class="right"></b>
                    <div class="center">
                        <i class="circle"></i>
                        <p>
                            <span class="month"></span>
                            <span class="year">
                                    <b>月</b><br />
                                    <b></b>
                                </span>
                        </p>
                        <i class="circle"></i>
                    </div>
                </div>

                <i class="triangles"></i>
                <!--星期-->
                <div class="calendar-week">
                    <ul class="week-list"></ul>
                </div>

            </div>
            <div class="container-center">
                <div class="device">
                    <a class="arrow-left" href="#"></a>
                    <a class="arrow-right" href="#"></a>
                    <div class="swiper-container container">
                        <div class="swiper-wrapper box-center swiper" id="list">

                        </div>
                    </div>
                    <div class="pagination"></div>
                </div>
                <!--库存-->
                <div class="stock zHide"><b class="m"></b>月<b class="d"></b>日出发仅剩<b class="nums">  </b>个余位</div>
            </div>
        </div>
    </div>


js:

 /***
     * @CreateCalendar 构造函数,统筹日历
     */
    var CreateCalendar = {
        create:function(){
            'use strict';
            var CreateCalendar ={
                init:function(){    //  初始化函数
                    // to do ...
                    this.changeTitle();
                    this.addWeekColor();
                    this.getDateCur();
                },
                addWeekColor:function(){  //    周六日 title
                    var _weekList = document.getElementsByClassName('week-list')[0],
                        _li = _weekList.getElementsByTagName('li'),_len=_li.length;
                    _li[0].style.color = 'red';
                    _li[_len - 1].style.color = 'red';
                },
                getDateCur:function(){  //  添加“今天,明天,后天”
                    var GetDateStr = function(){
                        var _dd = new Date();
                        _dd.setDate(_dd.getDate()); //  获取
                        var _y = _dd.getFullYear(),_m=_dd.getMonth()+1,_d = _dd.getDate();
                        return _y + '-' + _m +'-' +_d;
                    };
                    var _cBox =document.getElementsByClassName('box-center')[0],
                        _calendars = document.getElementsByClassName('calendar-box'),
                        _cLens = _calendars.length,
                        _ul = document.getElementsByClassName('day-list');

                    for(var i=0;i<_ul.length;i++){
                        var _li = _ul[i].childNodes;
                        for(var j=0;j<_li.length;j++){
                            _li[j].setAttribute('data-index',j);
                            var _date = _li[j].getAttribute('data-time');
                            if(_date == GetDateStr(0)){
                                console.log('今天是:'+_li[j].getAttribute('data-time'));
                                if(!_li[j].className.match(new RegExp('(\\s|^)' + 'now' + '(\\s|$)'))){ //今天添加now
                                    _li[j].className += ' '+ 'now';
                                }
                                if(_li[j].className.match(new RegExp('(\\s|^)' + 'off' + '(\\s|$)'))){
                                    _li[j].className = _li[j].className.replace(new RegExp('(\\s|^)' + 'off' + '(\\s|$)'), '');
                                }
                            }
                        }
                    }
                    /**
                     * @_nowset class为now的日期转化为时间戳
                     * @_dataset    获得所有日期转化为时间戳
                     * @_dataset 与 _nowset  进行对比,小于_nowset的禁止用户点击 
                     */
                    var _nowset = Date.parse(new Date(document.getElementsByClassName('now')[0].dataset.time)) / 1000;  //  
                    console.log('今天时间戳:'+_nowset);

                    for(var i=0;i<_ul.length;i++){
                        // _ul[i].index = i;
                        var _li = _ul[i].childNodes;
                        for(var j=0;j<_li.length;j++){                
                            var _dateset = Date.parse(new Date(_li[j].dataset.time)) / 1000;
                            if(_li[j].dataset.time){
                                // var _less = _li[j].dataset.time;
                                if(_dateset < _nowset){
                                    _li[j].classList.add('off');
                                    // if(!_li[j].className.match(new RegExp('(\\s|^)' + 'over' + '(\\s|$)'))){ //今天添加now
                                    //     _li[j].className += ' '+ 'over';
                                    // }
                                    _li[j].classList.add('over');   //今天之前的日期
                                    _li[j].onclick = function(){
                                        return false;
                                    };
                                }
                            }

                        }
                    }

                    var _now = document.getElementsByClassName('now')[0];
                    _now.childNodes[0].innerHTML = '今天';

                },
                changeTitle:function(){ //点击切换左右按钮
                    var _switchBtn = document.getElementsByClassName('switch-btn')[0],
                        _left = _switchBtn.getElementsByClassName('left')[0],
                        _right = _switchBtn.getElementsByClassName('right')[0];
                    _left.onclick = function(){     //点击左侧月份按钮
                        swiper.prev();
                        
                        setTimeout(function(){
                            changeMonth();
                        },500);
                    };
                    _right.onclick = function(){    //点击右侧月份按钮
                        swiper.next();
                        setTimeout(function(){
                            changeMonth();
                        },500);
                    };
                }
            };
            return CreateCalendar;
        }
    };

    var myCalendar = CreateCalendar.create();
    myCalendar.init();


温馨提示:由于代码较多,已经上传Github:https://hzaini1989.github.io/-js-calendar/    点击打开链接

或者有需要源码到可以留下邮箱!

先附上源码:https://github.com/hzaini1989/-js-calendar

Vue.js 中结合 Swiper 5 和 ECharts 5 来实现多个仪表盘的左右滚动效果,你可以按照以下步骤操作: 1. **安装依赖**: - 首先,确保已经安装了 VueSwiper 和 ECharts 的 npm 包。如果没有,可以分别运行 `npm install vue swiper echarts`。 2. **组件化开发**: - 创建一个新的 Vue 组件,比如 `DashboardPanel.vue`,用于展示单个仪表盘。在这个组件内部,你可以创建一个 Swiper 实例来控制左右滑动,并嵌套 ECharts 的图表实例。 ```html <template> <div class="dashboard-container"> <swiper :options="swiperOptions"> <swiper-slide v-for="(chartData, index) in chartDataList" :key="index"> <div class="chart-wrapper"> <echarts :options="chartData.options"></echarts> </div> </swiper-slide> </swiper> </div> </template> <script> import { SuiSwiper } from 'vue-awesome-swiper'; import ECharts from '@echarts/core'; export default { components: { SuiSwiper, }, data() { return { swiperOptions: { // Swiper 滑块配置 // ... }, chartDataList: [], // 存放每个仪表盘的数据列表 }; }, // 在这里添加获取和初始化图表数据的方法 } </script> ``` 3. **初始化图表数据**: - 根据需求从服务器或本地获取多个仪表盘的数据,存储在 `chartDataList` 数组中,每个数据项包含图表的配置选项。 4. **Swiper 配置**: - 在 `swiperOptions` 中设置 Swiper 的基本属性,如自动切换时间间隔、循环次数等。同时,也可以通过修改 Swiper 相关事件监听函数来更新 ECharts 图表。 ```js data() { return { swiperOptions: { loop: true, autoplay: { delay: 3000, }, onSlideChangeEnd: this.updateChartsPosition, }, // ... }; }, methods: { updateChartsPosition(swiper) { const currentIndex = swiper.realIndex; this.$set(this.chartDataList, currentIndex, this.chartDataList[currentIndex + 1]); this.$set(this.chartDataList, currentIndex + 1, null); }, } ```
评论 29
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值