欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生js開(kāi)發(fā)的日歷插件

 更新時(shí)間:2017年02月04日 11:41:05   作者:gaoxiaosong1113  
本文主要分享了原生js開(kāi)發(fā)的日歷插件的示例代碼。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧

效果如下所示:

代碼如下:

<style type="text/css">
 * {
 margin: 0;
 padding: 0;
 }
 ul, li {
 list-style: none;
 }
 #week {
 width: 350px;
 height: 350px;
 border: 1px solid #ccc;
 }
 #week h6 {
 font-size: 20px;
 overflow: hidden;
 height: 40px;
 line-height: 40px;
 }
 #week h6 div {
 float: left;
 width: 250px;
 text-align: center;
 }
 #week .prev {
 float: left;
 font-size: 12px;
 width: 50px;
 cursor: pointer;
 }
 #week .next {
 float: right;
 font-size: 12px;
 width: 50px;
 cursor: pointer;
 }
 #week p span {
 width: 50px;
 float: left;
 text-align: center;
 height: 30px;
 line-height: 30px;
 }
 #week p {
 background: #ccc;
 overflow: hidden;
 height: 30px;
 }
 #week ul {
 margin-top: 10px;
 }
 #week ul li {
 width: 50px;
 float: left;
 text-align: center;
 height: 30px;
 cursor: pointer;
 }
 </style>
<input type="text" id="ele" onfocus="currentWeek(this)"/>
<script>
 function currentWeek(ele) {
 var obj = offset(ele);
 var x = obj.left;
 var y = obj.top + ele.offsetHeight + 1;
 //創(chuàng)建日歷界面
 if (!document.getElementById('week')) {
 var oDiv = document.createElement('div');
 document.body.appendChild(oDiv);
 oDiv.id = 'week';
 oDiv.style.top = y + "px";
 oDiv.style.left = x + "px";
 //創(chuàng)建日歷title
 var h6 = document.createElement('h6');
 oDiv.appendChild(h6);
 var prev = document.createElement('div');
 h6.appendChild(prev);
 prev.className = 'prev';
 prev.innerHTML = '上個(gè)月';
 var content = document.createElement('div');
 content.className = "content";
 h6.appendChild(content);
 var next = document.createElement('div');
 h6.appendChild(next);
 next.className = 'next';
 next.innerHTML = '下個(gè)月';
 //創(chuàng)建星期日到星期六的文字行
 var oPs = document.createElement('p');
 oPs.className = "rlTitle";
 oDiv.appendChild(oPs);
 var opsCont = ['日', '一', '二', '三', '四', '五', '六'];
 for (var i = 0; i <= 6; i++) {
 var oSpan = document.createElement('span');
 oPs.appendChild(oSpan);
 oSpan.innerHTML = opsCont[i];
 }
 //創(chuàng)建日歷上面的日期行數(shù)所需要的變量
 var oUl = document.createElement('ul');
 oUl.className = "rlCenter";
 oDiv.appendChild(oUl);
 var currentDate = new Date();
 var currentYear = currentDate.getFullYear();
 var currentMonth = currentDate.getMonth();
 active(currentMonth);//傳參數(shù)月份
 //創(chuàng)建日歷上下翻月
 prev.onclick = function () {
 active(--currentMonth);
 };
 next.onclick = function () {
 active(++currentMonth);
 };
 }
 //動(dòng)態(tài)創(chuàng)建日歷上面日期,變包裝成方法
 function active(m) {
 oUl.innerHTML = ''; //切忌一定要把這個(gè)內(nèi)容去掉,要不然會(huì)點(diǎn)一次翻頁(yè)都在日歷下面依次顯示出來(lái)
 var activeDate = new Date(currentYear, m, 1); //外面?zhèn)鬟M(jìn)來(lái)的不斷變化的日期對(duì)象
 var year = activeDate.getFullYear();
 var month = activeDate.getMonth(); //把當(dāng)前的月份保存下來(lái)只是為了給title獲取月份
 content.innerHTML = year + '年' + (month + 1) + '月';
 //創(chuàng)建日歷上面的日期行數(shù)
 var n = 1 - activeDate.getDay();
 if (n == 1) {
 n = -6;
 } //為了日歷更友好的顯示三個(gè)月,讓用戶(hù)看的更明白。
 activeDate.setDate(n); //如果n為負(fù)數(shù),則減少月份.在用這個(gè)月最后一天減去這個(gè)值就可以獲得日歷從哪天開(kāi)始的。
 for (var i = 0; i < 42; i++) {
 var oLi = document.createElement('li');
 oUl.appendChild(oLi);
 var date = activeDate.getDate(); //返回日期1-31號(hào)
 oLi.innerHTML = date;
 oLi.dateValue = year + "-" + (activeDate.getMonth() + 1) + "-" + date; //這里必須是activeDate.getMonth()+1,不能用m+1。因?yàn)檫@個(gè)是一直變化的。要不然日歷不管點(diǎn)哪天都是屬于當(dāng)前月份的。
 oLi.onclick = function () {
  ele.value = this.dateValue;//文本框獲取的年月日
  document.body.removeChild(oDiv); //獲取到年月日,日歷取消
  oDiv = null;
 };
 if (activeDate.getMonth() != month) {
  oLi.style.color = "#ccc"; //不是本月的天數(shù)顏色變成灰色 
 }
 //切忌下面這個(gè)增加天數(shù)語(yǔ)句,一定要判斷完上面是不是本月的天數(shù),然后在添加這條增加語(yǔ)句,要不然會(huì)出現(xiàn)錯(cuò)誤。
 activeDate.setDate(date + 1); //如果超出該月份應(yīng)有的天數(shù)則增加月份
 }
 }
 }
 function offset(ele) {
 var l = ele.offsetLeft;
 var t = ele.offsetTop;
 var p = ele.offsetParent;
 while (p) {
 if (window.navigator.userAgent.indexOf("MSIE 8") > -1) {
 l += p.offsetLeft;
 t += p.offsetTop;
 } else {
 l += p.offsetLeft + p.clientLeft;
 t += p.offsetTop + p.clientTop;
 }
 p = p.offsetParent;
 }
 return {
 left: l,
 top: t
 }
 }
</script>

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • 微信小程序轉(zhuǎn)盤(pán)抽獎(jiǎng)的實(shí)現(xiàn)方法

    微信小程序轉(zhuǎn)盤(pán)抽獎(jiǎng)的實(shí)現(xiàn)方法

    這篇文章主要為大家詳細(xì)介紹了微信小程序轉(zhuǎn)盤(pán)抽獎(jiǎng)的實(shí)現(xiàn)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • JavaScript實(shí)現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法

    JavaScript實(shí)現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法,涉及javascript字符串操作的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • js父頁(yè)面與子頁(yè)面不同時(shí)顯示的方法

    js父頁(yè)面與子頁(yè)面不同時(shí)顯示的方法

    這篇文章主要介紹了js父頁(yè)面與子頁(yè)面不同時(shí)顯示的方法,打開(kāi)一個(gè)頁(yè)面后,父頁(yè)面DISABLE,在子頁(yè)面關(guān)閉后,父頁(yè)面ENABLE,是比較實(shí)用的技巧,需要的朋友可以參考下
    2014-10-10
  • JS實(shí)現(xiàn)的Select三級(jí)下拉菜單代碼

    JS實(shí)現(xiàn)的Select三級(jí)下拉菜單代碼

    這篇文章主要介紹了JS實(shí)現(xiàn)的Select三級(jí)下拉菜單,涉及javascript動(dòng)態(tài)創(chuàng)建下拉列表的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-08-08
  • 原生Javascript實(shí)現(xiàn)五角星評(píng)分

    原生Javascript實(shí)現(xiàn)五角星評(píng)分

    這篇文章主要為大家詳細(xì)介紹了原生Javascript實(shí)現(xiàn)五角星評(píng)分,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • 深入理解 ES6中的 Reflect用法

    深入理解 ES6中的 Reflect用法

    這篇文章主要介紹了深入理解 ES6中的 Reflect用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • Nuxt v-bind綁定img src不顯示的解決

    Nuxt v-bind綁定img src不顯示的解決

    這篇文章主要介紹了Nuxt v-bind綁定img src不顯示的解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • vue/js實(shí)現(xiàn)頁(yè)面自動(dòng)往上滑動(dòng)效果

    vue/js實(shí)現(xiàn)頁(yè)面自動(dòng)往上滑動(dòng)效果

    這篇文章主要為大家詳細(xì)介紹了vue/js實(shí)現(xiàn)頁(yè)面自動(dòng)往上滑動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Bootstrap導(dǎo)航條的使用和理解3

    Bootstrap導(dǎo)航條的使用和理解3

    這篇文章主要為大家詳細(xì)介紹了關(guān)于Bootstrap導(dǎo)航條的使用和理解的學(xué)習(xí)記錄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • echarts控制x軸和y軸name位置并加軸箭頭代碼示例

    echarts控制x軸和y軸name位置并加軸箭頭代碼示例

    搞數(shù)據(jù)展示,很多朋友都會(huì)用到免費(fèi)的echarts,下面這篇文章主要給大家介紹了關(guān)于echarts控制x軸和y軸name位置并加軸箭頭的相關(guān)資料,需要的朋友可以參考下
    2024-01-01

最新評(píng)論