麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > HTML > 正文

HTML5實現簽到 功能

2024-08-26 00:21:04
字體:
來源:轉載
供稿:網友

Introduce(介紹)

用戶簽到的H5例子(css+jquery,無圖片),由于網上找的的用戶簽到例子都不好,要不就是好多圖片組成的,要不就大量冗余代碼,所以特意做了個簽到界面(移動端)。

User sign sample page for mobile using h5 which only use css + jquery + html.

Demo

https://fallstar0.github.io/SignSample/

Shot(截圖)

HTML5,簽到

HTML5,簽到

一些關鍵的地方

這個功能的編寫思路是,先構建日期和簽到相關數據,然后從服務端獲取數據,并對原有數據進行更改,最后進行渲染。

這樣子很好的擺脫了邏輯比較凌亂的問題,并且可以直接將這些數據用 vue.js 來掛載(本文沒有這樣做)。

生成日期數據

//生成日期數據    function buildData() {        var da = {            dates: [],//日期數據,從1號開始            current: '',//當前日期            monthFirst: 1,//獲取當月的1日等于星期幾            month: 0,//當前月份            days: 30,//當前月份共有多少天            day: 0,//今天幾號了            isSigned: false,//今天是否已經簽到            signLastDays:3,//連續簽到日子            signToday: function () {                this.isSigned = true;                this.dates[this.day].isSigned = true;            },        };        var ds = [];        //初始化日期數據        var dt = new Date();        da.current = dt.ToString('yyyy年M月d日');        da.monthFirst = new Date(dt.getFullYear(), dt.getMonth(), 1).getDay();        da.month = dt.getMonth() + 1;        da.days = new Date(dt.getFullYear(), parseInt(da.month), 0).getDate();//獲取當前月的天數        da.day = dt.getDate();        for (var i = 1; i < da.days + 1; i++) {            var o = {                isSigned: false,//是否簽到了                num: i,//日期                isToday: i == da.day,//是否今天                isPass: i < da.day,//時間已過去            };            ds[i] = o;        }        da.dates = ds;        return da;    }

 

有了數據之后,就可以將數據轉換為界面了

 //渲染數據    function renderData(da) {        var signDays = document.getElementById('spSignDays');        signDays.innerText = da.signLastDays;        var root = document.getElementById("signTable");        root.innerHTML = '';        var tr, td;        var st = da.monthFirst;        var dates = da.dates;        var rowcount = 0;        //最多6行        for (var i = 0; i < 42; i++) {            if (i % 7 == 0) {                //如果沒有日期了,中斷                if (i > (st + da.days))                    break;                tr = document.createElement('tr');                tr.className = 'darkcolor trb';                root.appendChild(tr);                rowcount++;            }            //前面或后面的空白            if (i < st || !dates[i - st + 1]) {                td = document.createElement('td');                td.innerHTML = '<div class="sign-blank"><span></span></div>';                tr.appendChild(td);                continue;            }            //填充數字部分            var d = dates[i - st + 1];            td = document.createElement('td');            var tdcss = '';            if (d.isToday)                tdcss = 'sign-today';            else if (d.isPass)                tdcss = 'sign-pass';            else                tdcss = 'sign-future';            if (d.isSigned) {                tdcss = 'sign-signed ' + tdcss;                td.innerHTML = '<div class="' + tdcss + '"><span>' + d.num + '</span><svg xmlns="http://www.w3.org/2000/svg" version="1.1" class="sign-pin svg-triangle "><polygon points="0,0 35,0 0,35" /></svg></div>';            } else {                tdcss = 'sign-unsign ' + tdcss;                td.innerHTML = '<div class="' + tdcss + '"><span>' + d.num + '</span></div>';            }            tr.appendChild(td);        }        //計算是否需要添加最后一行        if ((st + da.days + 1) / 7 > rowcount)            root.appendChild(tr);    }       //構建日期數據        var da = buildData();        //渲染        renderData(da);

 

Copyright

Author [email protected]

https://github.com/FallStar0/SignSample

https://gitee.com/fallstar/SignSample


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品久久久久影院老司 | 黑人日比| 激情福利视频 | 久久免费视频3 | 在线中文字幕网站 | 免费毛片儿 | 国产精品久久久久久久av三级 | 欧美日韩在线视频一区 | 日韩美女电影 | 欧美黄色视屏 | 双性帝王调教跪撅打屁股 | 国产三级在线观看a | 日韩中文字幕三区 | 久国产精品视频 | 成人不卡免费视频 | 精品一区二区在线观看视频 | 日韩伦理电影免费观看 | 欧美日韩国产成人在线 | 日本爽快片100色毛片视频 | 中文字幕国 | 黄色7777| 成人做爰高潮片免费视频韩国 | 99爱国产精品| av免费在线观 | 精品二区在线观看 | 中文字幕 亚洲一区 | 久久国产精品久久久久久电车 | 一级电影在线免费观看 | 中国洗澡偷拍在线播放 | 久久中文免费 | av在线免费看网站 | 亚洲卡通动漫在线观看 | 成人在线视频国产 | 亚洲成人欧美在线 | www.com香蕉 | 青草视频在线观看视频 | 最新欧美精品一区二区三区 | 国产99久久| 精品一区二区三区在线视频 | 色人阁导航 | 免费毛片小视频 |