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

首頁 > 開發(fā) > HTML5 > 正文

HTML5實(shí)現(xiàn)簽到 功能

2024-09-05 07:22:41
字體:
供稿:網(wǎng)友

Introduce(介紹)

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

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

Demo

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

Shot(截圖)

一些關(guān)鍵的地方

這個(gè)功能的編寫思路是,先構(gòu)建日期和簽到相關(guān)數(shù)據(jù),然后從服務(wù)端獲取數(shù)據(jù),并對(duì)原有數(shù)據(jù)進(jìn)行更改,最后進(jìn)行渲染。

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

生成日期數(shù)據(jù)

//生成日期數(shù)據(jù)    function buildData() {        var da = {            dates: [],//日期數(shù)據(jù),從1號(hào)開始            current: '',//當(dāng)前日期            monthFirst: 1,//獲取當(dāng)月的1日等于星期幾            month: 0,//當(dāng)前月份            days: 30,//當(dāng)前月份共有多少天            day: 0,//今天幾號(hào)了            isSigned: false,//今天是否已經(jīng)簽到            signLastDays:3,//連續(xù)簽到日子            signToday: function () {                this.isSigned = true;                this.dates[this.day].isSigned = true;            },        };        var ds = [];        //初始化日期數(shù)據(jù)        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();//獲取當(dāng)前月的天數(shù)        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,//時(shí)間已過去            };            ds[i] = o;        }        da.dates = ds;        return da;    }

 

有了數(shù)據(jù)之后,就可以將數(shù)據(jù)轉(zhuǎn)換為界面了

 //渲染數(shù)據(jù)    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;            }            //填充數(shù)字部分            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);        }        //計(jì)算是否需要添加最后一行        if ((st + da.days + 1) / 7 > rowcount)            root.appendChild(tr);    }       //構(gòu)建日期數(shù)據(jù)        var da = buildData();        //渲染        renderData(da);

 

Copyright

Author [email protected]

https://github.com/FallStar0/SignSample

https://gitee.com/fallstar/SignSample
 

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 九九热九九热 | 国产精品久久久久久久久粉嫩 | 欧美一级特黄a | 成人毛片100部免费观看 | 性欧美一区 | 午夜视频中文字幕 | 久久97超碰 | 欧美黑大粗硬毛片视频 | 久久sp| 欧美毛片 | 成人情欲视频在线看免费 | 亚洲xxx在线观看 | 国产乱淫av| 91久久精品一二三区 | 一级大片一级一大片 | 久久精品小短片 | 特级黄色影院 | 小雪奶水翁胀公吸小说最新章节 | 毛片小网站 | 97人操| 黄色网址在线视频 | 成人在线视频国产 | 一区二区三区日韩电影 | 91美女视频在线 | 在线成人免费av | 手机视频在线播放 | 成人精品视频网站 | 中文字幕一区二区三区四区 | 午夜天堂在线视频 | 中文字幕电影免费播放 | 久久久久久久久久91 | 爱唯侦察 国产合集 亚洲 | 一级电影免费 | 久久国产综合精品 | 今井夏帆av一区二区 | 日韩中文一区 | 国产91丝袜在线播放 | 久久午夜免费视频 | 亚洲一区二区中文字幕在线观看 | 黄色网战入口 | 小视频免费在线观看 |