一款很好用的 Vue audio 插件 vue-audio-better
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一款很好用的 Vue audio 插件 vue-audio-better相关的知识,希望对你有一定的参考价值。
参考技术A Type: String[] - RequiredAn array of audio file urls
Type: Boolean - Default: false
Whether to force html5 Audio
Type: Boolean - Default: false
Whether to start the playback again
automatically after it is done playing
Type: Boolean - Default: true
Whether to start downloading the audio
file when the component is mounted
Type: Boolean - Default: false
Whether to start the playback
when the component is mounted
Type: String[] - Default: []
Howler.js automatically detects your file format from the extension,
but you may also specify a format in situations where extraction won't work
(such as with a SoundCloud stream)
Type: Boolean - Default: false
Whether to enable the withCredentials flag on XHR requests
used to fetch audio files when using Web Audio API ( see reference )
Bundle the js to the dist folder:
howler.js
vue-howler
MIT
一款很好用的前端公农历转换插件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no"> <title>rui-datepicker公农历日期选择器</title> <style> h1,h2,h3,h4,h5,h6,body,pmargin:0; bodybackground: #444;font-size: 14px/1.2; a,bodycolor: #fc0; atext-decoration: none; headerbackground: #fc0;color: #333;padding:10px;text-align: center; header pmargin:10px 0; header adisplay: inline-block;height: 34px;padding:0 16px;line-height: 32px;background: #333;color: #fc0;border-radius: 5px; .date_inputtext-align: center;margin:16px 0 0; .date_input ppadding:0 0 8px;font-size: 1.4em .date_input inputwidth: 80%;height: 50px;font-size: 18px;border: 1px solid #444;border-radius: 5px;padding: 5px;margin:0 10%;box-sizing: border-box; </style> <!-- <link rel="stylesheet" href="../dist/rui-datepicker.min.css"> --> <!-- <script src="../dist/rui-datepicker.min.js"></script> --> <link rel="stylesheet" href="rui_date.css"> <script src="rui_date.js?v=2019"></script> <script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script> </head> <body> <div class="date_input"> <p>不带时辰</p> <input id="demo1" type="text" data-toid-date="date" name="input_date" placeholder="日期选择不带时辰" data-type="1" data-date="1983-6-3" /></input> <input type="hidden" id="date" name="date"> </div> <div class="date_input"> <p>带时辰</p> <input id="demo2" type="text" data-toid-date="date1" data-toid-hour="hour1" data-toid-minute="min1" name="input_date" placeholder="日期选择带时辰" readonly="readonly"/> <input type="hidden" id="date1" name="date"> <input type="hidden" id="hour1" name="hour"> <input type="hidden" id="min1" name="mini"> </div> <button onclick="sub()" style="width:200px;height: 50px;background-color: aqua;margin-left: 200px;margin-top: 100px">console</button> <script> var date1 = new ruiDatepicker().init(‘#demo1‘); var date2 = new ruiDatepicker().init(‘#demo2‘); function sub() var h=$(‘#hour1‘).val(); var m=$(‘#min1‘).val(); var d=$(‘#date1‘).val(); console.log(d);console.log(h);console.log(m); </script> </body> </html>
.gearDate font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;font-size: 10px;background-color: rgba(0, 0, 0, 0.2);display: block;position: absolute;position: fixed;top: 0;left: 0;width: 100%;height: 100%;z-index: 2018917;overflow: hidden;-webkit-animation-fill-mode: both;animation-fill-mode: both;-webkit-transform: translateZ(0); .date_ctrl vertical-align: middle;background-color: #F0F0F0;border:1px solid #a5a5a5;border-radius: 5px;color: #363837;margin: 0;height: auto;width: 90%;max-width: 600px;position: absolute;left: 0;right:0;top: 12%;z-index: 9902;overflow: hidden;margin:0 auto;-webkit-transform: translateY(0);transform: translateY(0);-ms-transform: translateY(0);-moz-transform: translateY(0); .slideInUp animation: slideInUp .3s ease-in;-webkit-animation: slideInUp .3s ease-in;-ms-animation: slideInUp .3s ease-in;-moz-animation: slideInUp .3s ease-in @-webkit-keyframes slideInUp 0% -webkit-transform: translateY(-100%);transform: translateY(-100%);-moz-transform: translateY(-100%);-ms-transform: translateY(-100%);-o-transform: translateY(-100%) 100% -webkit-transform: translateY(0);transform: translateY(0);-moz-transform: translateY(0);-o-transform: translateY(0);-ms-transform: translateY(0) @keyframes slideInUp 0% -webkit-transform: translateY(-100%);transform: translateY(-100%);-moz-transform: translateY(-100%);-ms-transform: translateY(-100%);-o-transform: translateY(-100%) 100% -webkit-transform: translateY(0);transform: translateY(0);-moz-transform: translateY(0);-o-transform: translateY(0);-ms-transform: translateY(0) @-moz-keyframes slideInUp 0% -webkit-transform: translateY(-100%);transform: translateY(-100%);-moz-transform: translateY(-100%);-ms-transform: translateY(-100%);-o-transform: translateY(-100%) 100% -webkit-transform: translateY(0);transform: translateY(0);-moz-transform: translateY(0);-o-transform: translateY(0);-ms-transform: translateY(0) @-ms-keyframes slideInUp 0% -webkit-transform: translateY(-100%);transform: translateY(-100%);-moz-transform: translateY(-100%);-ms-transform: translateY(-100%);-o-transform: translateY(-100%) 100% -webkit-transform: translateY(0);transform: translateY(0);-moz-transform: translateY(0);-o-transform: translateY(0);-ms-transform: translateY(0) .date_roll position: relative;width: 100%;height: auto;overflow: hidden;font-weight: bold;background-color: transparent;-webkit-mask: -webkit-gradient(linear, 0% 50%, 0% 100%, from(#debb47), to(rgba(36, 142, 36, 0)));-webkit-mask: -webkit-linear-gradient(top, #debb47 50%, rgba(36, 142, 36, 0)); .date_roll>divfont-size: 2em;height: 6em;float: left;background-color: transparent;position: relative;overflow: hidden;width: 33.33%; .date_roll_more>divwidth: 25%; .date_roll_minut>divwidth: 20%; .date_roll_mask padding:0 1em;-webkit-mask: -webkit-gradient(linear, 0% 40%, 0% 0%, from(#debb47), to(rgba(36, 142, 36, 0)));-webkit-mask: -webkit-linear-gradient(bottom, #debb47 50%, rgba(36, 142, 36, 0)); .date_grid position: relative;top: 2em;width: 100%;height: 2em;margin: 0;box-sizing: border-box;z-index: 0;background-color: #E8E8E8;border-top: 1px solid #d4d4d4;border-bottom: 1px solid #d4d4d4; .date_grid>div color: #000;position: absolute;right: 0;top: 0;font-size: .8em;line-height: 2.5em .date_info_boxcolor: #363837;font-size: 1.8em;text-align: center;padding: .6em 0;text-align: center;border-bottom: 1px solid #d4d4d4;font-weight: 700; .date_class_boxtext-align: center;padding:1em 2em; .date_classdisplay: inline-block;font-size: 1.4em;width:40%;padding:.4em 0;text-align: center;color: #c91723;border:1px solid #c91723;cursor: pointer; .date_class_box .date_class:first-childborder-top-left-radius: .2em;border-bottom-left-radius: .2em .date_class_box .date_class:last-childborder-top-right-radius: .2em;border-bottom-right-radius: .2em .date_class_box .activebackground-color: #c91723;color: #fff .date_btn_box overflow: hidden;position: relative;border-top:1px solid #d4d4d4;margin-top:1em; .date_btn color: #000;font-size: 1.6em;line-height: 1em;text-align: center;padding: .8em 1em;cursor: pointer;float: left;width: 49.9%;box-sizing: border-box; .lcalendar_cancelfloat:left !important; .lcalendar_finishfloat:right !important; .date_btn.lcalendar_cancelborder-right:1px solid #d4d4d4; .gear float: left;position: absolute;z-index: 9902;width: 5.5em;margin-top: -6em;cursor: pointer;padding:2em 0; .date_roll>div .gear width: 100%;color:#000; .tooth height: 2em;line-height: 2em;text-align: center;overflow: hidden;
/* * ruiDatePicker 农历公历-日历控件 * 版本:1.0 * 作者:羯瑞 * 邮箱:410232098@qq.com * 创建于:2016-12-31 * 修改:于2018-04-10 下午 永恒的微笑修改 * 更新:增加了第三种模式:添加了分钟选项 * 使用方法: 1、只有年月日:data-toid-date="保存年月日隐藏id" 2、年月日时data-toid-date="保存年月日隐藏id" data-toid-hour="保存小时隐藏域id" 3、年月日时分data-toid-date="保存年月日隐藏id" data-toid-hour="保存小时隐藏域id" data-toid-minute="保存分钟隐藏域id" 返回值绑定:历法:data-toid-calendar="历法id" */ window.ruiDatepicker = (function () // 兼容IE-classList处理 if (!("classList" in document.documentElement)) Object.defineProperty(HTMLElement.prototype, ‘classList‘, get: function () var self = this; function update(fn) return function (value) var classes = self.className.split(/\s+/g), index = classes.indexOf(value); fn(classes, index, value); self.className = classes.join(" "); return add: update(function (classes, index, value) if (!~index) classes.push(value); ), remove: update(function (classes, index) if (~index) classes.splice(index, 1); ), toggle: update(function (classes, index, value) if (~index) classes.splice(index, 1); else classes.push(value); ), contains: function (value) return !!~self.className.split(/\s+/g).indexOf(value); , item: function (i) return self.className.split(/\s+/g)[i] || null; ; ); var datePicker = function () this.gearDate; this.minY = 1940; this.minM = 1, this.minD = 1, this.maxY = 2020, this.maxM = 12, this.maxD = 31, this.type = 1 //0公历,1农历 datePicker.prototype = init: function (id) this.trigger = document.querySelector(id); this.bindEvent(‘date‘); , bindEvent: function (type) var _self = this; // 农历数据 var LunarCal = [ new tagLunarCal(38, 0, 0, 38, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1), /* 1940 */ new tagLunarCal(26, 6, 2, 44, 1, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0), new tagLunarCal(45, 0, 3, 49, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0), new tagLunarCal(35, 0, 4, 54, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1), new tagLunarCal(24, 4, 5, 59, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1), /* 1944 */ new tagLunarCal(43, 0, 0, 5, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 1), new tagLunarCal(32, 0, 1, 10, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1), new tagLunarCal(21, 2, 2, 15, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1), new tagLunarCal(40, 0, 3, 20, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1), /* 1948 */ new tagLunarCal(28, 7, 5, 26, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1), new tagLunarCal(47, 0, 6, 31, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1), new tagLunarCal(36, 0, 0, 36, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0), new tagLunarCal(26, 5, 1, 41, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1), /* 1952 */ new tagLunarCal(44, 0, 3, 47, 0, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1), new tagLunarCal(33, 0, 4, 52, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0), new tagLunarCal(23, 3, 5, 57, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1), new tagLunarCal(42, 0, 6, 2, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1), /* 1956 */ new tagLunarCal(30, 8, 1, 8, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0), new tagLunarCal(48, 0, 2, 13, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0), new tagLunarCal(38, 0, 3, 18, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1), new tagLunarCal(27, 6, 4, 23, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0), /* 1960 */ new tagLunarCal(45, 0, 6, 29, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0), new tagLunarCal(35, 0, 0, 34, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1), new tagLunarCal(24, 4, 1, 39, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0), new tagLunarCal(43, 0, 2, 44, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0), /* 1964 */ new tagLunarCal(32, 0, 4, 50, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1), new tagLunarCal(20, 3, 5, 55, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0), new tagLunarCal(39, 0, 6, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0), new tagLunarCal(29, 7, 0, 5, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1), /* 1968 */ new tagLunarCal(47, 0, 2, 11, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1), new tagLunarCal(36, 0, 3, 16, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0), new tagLunarCal(26, 5, 4, 21, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0, 1), new tagLunarCal(45, 0, 5, 26, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1), /* 1972 */ new tagLunarCal(33, 0, 0, 32, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1), new tagLunarCal(22, 4, 1, 37, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1), new tagLunarCal(41, 0, 2, 42, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1), new tagLunarCal(30, 8, 3, 47, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1), /* 1976 */ new tagLunarCal(48, 0, 5, 53, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1), new tagLunarCal(37, 0, 6, 58, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1), new tagLunarCal(27, 6, 0, 3, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0), new tagLunarCal(46, 0, 1, 8, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0), /* 1980 */ new tagLunarCal(35, 0, 3, 14, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 1), new tagLunarCal(24, 4, 4, 19, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1), new tagLunarCal(43, 0, 5, 24, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1), new tagLunarCal(32, 10, 6, 29, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1), /* 1984 */ new tagLunarCal(50, 0, 1, 35, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0), new tagLunarCal(39, 0, 2, 40, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1), new tagLunarCal(28, 6, 3, 45, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0, 0), new tagLunarCal(47, 0, 4, 50, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1), /* 1988 */ new tagLunarCal(36, 0, 6, 56, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 0), new tagLunarCal(26, 5, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1), new tagLunarCal(45, 0, 1, 6, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0), new tagLunarCal(34, 0, 2, 11, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0), /* 1992 */ new tagLunarCal(22, 3, 4, 17, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0), new tagLunarCal(40, 0, 5, 22, 1, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0), new tagLunarCal(30, 8, 6, 27, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1), new tagLunarCal(49, 0, 0, 32, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1), /* 1996 */ new tagLunarCal(37, 0, 2, 38, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1), new tagLunarCal(27, 5, 3, 43, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1), new tagLunarCal(46, 0, 4, 48, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1), /* 1999 */ new tagLunarCal(35, 0, 5, 53, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1), /* 2000 */ new tagLunarCal(23, 4, 0, 59, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1), new tagLunarCal(42, 0, 1, 4, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1), new tagLunarCal(31, 0, 2, 9, 1, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0), new tagLunarCal(21, 2, 3, 14, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1), /* 2004 */ new tagLunarCal(39, 0, 5, 20, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1), new tagLunarCal(28, 7, 6, 25, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1), new tagLunarCal(48, 0, 0, 30, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 1), new tagLunarCal(37, 0, 1, 35, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1), /* 2008 */ new tagLunarCal(25, 5, 3, 41, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1), new tagLunarCal(44, 0, 4, 46, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1), new tagLunarCal(33, 0, 5, 51, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1), new tagLunarCal(22, 4, 6, 56, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0), /* 2012 */ new tagLunarCal(40, 0, 1, 2, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0), new tagLunarCal(30, 9, 2, 7, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1), new tagLunarCal(49, 0, 3, 12, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 0, 1), new tagLunarCal(38, 0, 4, 17, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0), /* 2016 */ new tagLunarCal(27, 6, 6, 23, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1), new tagLunarCal(46, 0, 0, 28, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0), new tagLunarCal(35, 0, 1, 33, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0), new tagLunarCal(24, 4, 2, 38, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1), /* 2020 */ new tagLunarCal(42, 0, 4, 44, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1), new tagLunarCal(31, 0, 5, 49, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0), new tagLunarCal(21, 2, 6, 54, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1), new tagLunarCal(40, 0, 0, 59, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1), /* 2024 */ new tagLunarCal(28, 6, 2, 5, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0), new tagLunarCal(47, 0, 3, 10, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 1), new tagLunarCal(36, 0, 4, 15, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1), new tagLunarCal(25, 5, 5, 20, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0), /* 2028 */ new tagLunarCal(43, 0, 0, 26, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1), new tagLunarCal(32, 0, 1, 31, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0) ]; //呼出日期插件 function popupDate(e) //阻止获得焦点 document.activeElement.blur(); _self.gearDate = document.createElement("div"); _self.gearDate.className = "gearDate"; // 判断是否启用分钟 if (_self.trigger.getAttribute(‘data-toid-minute‘)) _self.gearDate.innerHTML = ‘<div class="date_ctrl slideInUp">‘ + ‘<div class="date_info_box lcalendar_info">‘ + ‘</div>‘ + ‘<div class="date_class_box">‘ + ‘<div class="date_class lcalendar_gongli">公历</div>‘ + ‘<div class="date_class lcalendar_nongli">农历</div>‘ + ‘</div>‘ + ‘<div class="date_roll_mask">‘ + ‘<div class="date_roll date_roll_minut">‘ + ‘<div>‘ + ‘<div class="gear date_yy" data-datetype="date_yy"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘<div>‘ + ‘<div class="gear date_mm" data-datetype="date_mm"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘<div>‘ + ‘<div class="gear date_dd" data-datetype="date_dd"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘<div class="width">‘ + ‘<div class="gear date_hh" data-datetype="date_hh"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘<div>‘ + ‘<div class="gear date_min" data-datetype="date_min"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘</div>‘ + ‘<div class="date_btn_box">‘ + ‘<div class="date_btn lcalendar_cancel">取消</div>‘ + ‘<div class="date_btn lcalendar_finish">确定</div>‘ + ‘</div>‘ + ‘</div>‘; else if (_self.trigger.getAttribute(‘data-toid-hour‘)) // 判断是否启用时辰 _self.gearDate.innerHTML = ‘<div class="date_ctrl slideInUp">‘ + ‘<div class="date_info_box lcalendar_info">‘ + ‘</div>‘ + ‘<div class="date_class_box">‘ + ‘<div class="date_class lcalendar_gongli">公历</div>‘ + ‘<div class="date_class lcalendar_nongli">农历</div>‘ + ‘</div>‘ + ‘<div class="date_roll_mask">‘ + ‘<div class="date_roll date_roll_more">‘ + ‘<div>‘ + ‘<div class="gear date_yy" data-datetype="date_yy"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘<div>‘ + ‘<div class="gear date_mm" data-datetype="date_mm"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘<div>‘ + ‘<div class="gear date_dd" data-datetype="date_dd"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘<div class="width">‘ + ‘<div class="gear date_hh" data-datetype="date_hh"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘</div>‘ + ‘<div class="date_btn_box">‘ + ‘<div class="date_btn lcalendar_finish">确定</div>‘ + ‘<div class="date_btn lcalendar_cancel">取消</div>‘ + ‘</div>‘ + ‘</div>‘; else _self.gearDate.innerHTML = ‘<div class="date_ctrl slideInUp">‘ + ‘<div class="date_info_box lcalendar_info">‘ + ‘</div>‘ + ‘<div class="date_class_box">‘ + ‘<div class="date_class lcalendar_gongli">公历</div>‘ + ‘<div class="date_class lcalendar_nongli">农历</div>‘ + ‘</div>‘ + ‘<div class="date_roll_mask">‘ + ‘<div class="date_roll">‘ + ‘<div>‘ + ‘<div class="gear date_yy" data-datetype="date_yy"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘<div>‘ + ‘<div class="gear date_mm" data-datetype="date_mm"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘<div>‘ + ‘<div class="gear date_dd" data-datetype="date_dd"></div>‘ + ‘<div class="date_grid">‘ + ‘</div>‘ + ‘</div>‘ + ‘</div>‘ + ‘</div>‘ + ‘<div class="date_btn_box">‘ + ‘<div class="date_btn lcalendar_finish">确定</div>‘ + ‘<div class="date_btn lcalendar_cancel">取消</div>‘ + ‘</div>‘ + ‘</div>‘; document.body.appendChild(_self.gearDate); dateCtrlInit(); var hasTouch = ‘ontouchstart‘ in window; var lcalendar_cancel = _self.gearDate.querySelector(".lcalendar_cancel"); lcalendar_cancel.addEventListener(hasTouch ? ‘touchstart‘ : ‘click‘, closeMobileCalendar); var lcalendar_finish = _self.gearDate.querySelector(".lcalendar_finish"); lcalendar_finish.addEventListener(hasTouch?‘touchstart‘:‘click‘, finishMobileDate); lcalendar_finish.addEventListener(hasTouch ? ‘touchstart‘ : ‘click‘, popupShow); //document.getElementById(_self.trigger.getAttribute(‘data-toid-time‘)).addEventListener(hasTouch ? ‘touchstart‘ : ‘click‘, finishMobileDate); //document.getElementById(_self.trigger.getAttribute(‘data-toid-hide‘)).addEventListener(hasTouch ? ‘touchstart‘ : ‘click‘, closeMobileCalendar); var lcalendar_gongli = _self.gearDate.querySelector(".lcalendar_gongli"); var lcalendar_nongli = _self.gearDate.querySelector(".lcalendar_nongli"); lcalendar_gongli.addEventListener(hasTouch ? ‘touchstart‘ : ‘click‘, function () convertTap(‘gongli‘) , false); lcalendar_nongli.addEventListener(hasTouch ? ‘touchstart‘ : ‘click‘, function () convertTap(‘nongli‘) , false); var date_yy = _self.gearDate.querySelector(".date_yy"); var date_mm = _self.gearDate.querySelector(".date_mm"); var date_dd = _self.gearDate.querySelector(".date_dd"); var date_hh = _self.gearDate.querySelector(".date_hh"); var date_min = _self.gearDate.querySelector(".date_min"); //获取分钟对象 date_yy.addEventListener(‘touchstart‘, gearTouchStart); date_mm.addEventListener(‘touchstart‘, gearTouchStart); date_dd.addEventListener(‘touchstart‘, gearTouchStart); date_hh ? date_hh.addEventListener(‘touchstart‘, gearTouchStart) : ‘‘; date_min ? date_min.addEventListener(‘touchstart‘, gearTouchStart) : ‘‘; date_yy.addEventListener(‘mousedown‘, gearMouseSlide); date_mm.addEventListener(‘mousedown‘, gearMouseSlide); date_dd.addEventListener(‘mousedown‘, gearMouseSlide); date_hh ? date_hh.addEventListener(‘mousedown‘, gearMouseSlide) : ‘‘; date_min ? date_min.addEventListener(‘mousedown‘, gearMouseSlide) : ‘‘; date_yy.addEventListener(‘touchmove‘, gearTouchMove); date_mm.addEventListener(‘touchmove‘, gearTouchMove); date_dd.addEventListener(‘touchmove‘, gearTouchMove); date_hh ? date_hh.addEventListener(‘touchmove‘, gearTouchMove) : ‘‘; date_min ? date_min.addEventListener(‘touchmove‘, gearTouchMove) : ‘‘; date_yy.addEventListener(‘touchend‘, gearTouchEnd); date_mm.addEventListener(‘touchend‘, gearTouchEnd); date_dd.addEventListener(‘touchend‘, gearTouchEnd); date_hh ? date_hh.addEventListener(‘touchend‘, gearTouchEnd) : ‘‘; date_min ? date_min.addEventListener(‘touchend‘, gearTouchEnd) : ‘‘; // 阻止透视滑动 _self.gearDate.addEventListener("touchmove", function (e) e.preventDefault(); ); // 阻止鼠标滚轮事件 if (navigator.userAgent.indexOf("Firefox") > 0) _self.gearDate.addEventListener(‘DOMMouseScroll‘, function (e) e.preventDefault(); , false); date_yy.addEventListener(‘DOMMouseScroll‘, gearMouseRolling, false); date_mm.addEventListener(‘DOMMouseScroll‘, gearMouseRolling, false); date_dd.addEventListener(‘DOMMouseScroll‘, gearMouseRolling, false); date_hh ? date_hh.addEventListener(‘DOMMouseScroll‘, gearMouseRolling, false) : ‘‘; date_min ? date_min.addEventListener(‘DOMMouseScroll‘, gearMouseRolling, false) : ‘‘; else _self.gearDate.onmousewheel = function (e) return false ; date_yy.onmousewheel = gearMouseRolling; date_mm.onmousewheel = gearMouseRolling; date_dd.onmousewheel = gearMouseRolling; date_hh ? date_hh.onmousewheel = gearMouseRolling : ‘‘; date_min ? date_min.onmousewheel = gearMouseRolling : ‘‘; // 公历农历选择 function convertTap(type) var nongli = _self.gearDate.querySelector(".lcalendar_nongli"); var gongli = _self.gearDate.querySelector(".lcalendar_gongli"); var changeOn = 0; if (type == ‘nongli‘ && _self.type != 1) nongli.className = nongli.className.replace(/active/, "").replace(/(^\s*)|(\s*$)/g, "") + ‘ active‘; gongli.className = gongli.className.replace(/active/, ""); _self.type = 1; changeOn = 1; else if (type == ‘gongli‘ && _self.type != 0) nongli.className = nongli.className.replace(/active/, ""); gongli.className = gongli.className.replace(/active/, "").replace(/(^\s*)|(\s*$)/g, "") + ‘ active‘; _self.type = 0; changeOn = 1; //判断是否切换 if (changeOn) var passY = _self.maxY - _self.minY + 1; var val_yy = parseInt(Math.round(_self.gearDate.querySelector(".date_yy").getAttribute("val"))); var date_mm = parseInt(Math.round(_self.gearDate.querySelector(".date_mm").getAttribute("val"))) + 1; var date_dd = parseInt(Math.round(_self.gearDate.querySelector(".date_dd").getAttribute("val"))) + 1; var date_yy = val_yy % passY + _self.minY; var type = _self.type ? 0 : 1; // 农历转公历前判断是否有闰月 var rmNum = LunarCal[val_yy].Intercalation ? LunarCal[val_yy].Intercalation : 0; if (!_self.type && rmNum) if (rmNum == (date_mm - 1)) date_mm = -(date_mm - 1); else if (rmNum < (date_mm - 1)) date_mm = date_mm - 1; else date_mm = date_mm; var objDate = calendarConvert(type, date_yy, date_mm, date_dd);//返回转换对象 // 公历转农历后判断是否有闰月 var rmTip = LunarCal[objDate.yy - _self.minY].Intercalation ? LunarCal[objDate.yy - _self.minY].Intercalation : 0; if (rmTip && _self.type) if (objDate.mm < 0) objDate.mm = -objDate.mm + 1 else if (objDate.mm > rmTip) objDate.mm = objDate.mm + 1; _self.gearDate.querySelector(".date_yy").setAttribute("val", objDate.yy - _self.minY); _self.gearDate.querySelector(".date_mm").setAttribute("val", objDate.mm - 1); _self.gearDate.querySelector(".date_dd").setAttribute("val", objDate.dd - 1); _self.gearDate.querySelector(".date_yy").setAttribute("top", ‘‘); setDateGearTooth(); //初始化年月日插件默认值 function dateCtrlInit() var date = new Date(); var dateArr = yy: date.getYear(), mm: date.getMonth(), dd: date.getDate() - 1 ; if (/^\d4-\d1,2-\d1,2$/.test(_self.trigger.getAttribute(‘data-date‘))) rs = _self.trigger.getAttribute(‘data-date‘).match(/(^|-)\d1,4/g); dateArr.yy = rs[0] - _self.minY; dateArr.mm = rs[1].replace(/-/g, "") - 1; dateArr.dd = rs[2].replace(/-/g, "") - 1; else dateArr.yy = dateArr.yy + 1900 - _self.minY; ; _self.gearDate.querySelector(".date_yy").setAttribute("val", dateArr.yy); _self.gearDate.querySelector(".date_mm").setAttribute("val", dateArr.mm); _self.gearDate.querySelector(".date_dd").setAttribute("val", dateArr.dd); // 判断是否有时辰 if (_self.gearDate.querySelector(".date_hh")) var hour_val = 0; //检查是否设置了默认小时 if (_self.trigger.getAttribute(‘data-hour‘) && _self.trigger.getAttribute(‘data-hour‘) >= 0) hour_val = parseInt(Math.round(_self.trigger.getAttribute(‘data-hour‘)) + 1); _self.gearDate.querySelector(".date_hh").setAttribute("val", hour_val); // 判断是否有分钟 if (_self.gearDate.querySelector(".date_min")) var minute_val = 0; //检查是否设置了默认分钟数 if (_self.trigger.getAttribute(‘data-minute‘) && _self.trigger.getAttribute(‘data-minute‘) >= 0) minute_val = parseInt(Math.round(_self.trigger.getAttribute(‘data-minute‘)) + 1); _self.gearDate.querySelector(".date_min").setAttribute("val", minute_val); // 默认农历或公历 if (parseInt(_self.trigger.getAttribute(‘data-type‘))) _self.type = 1; var nongli = _self.gearDate.querySelector(".lcalendar_nongli"); nongli.className = nongli.className.replace(/active/, "").replace(/(^\s*)|(\s*$)/g, "") + ‘ active‘; var passY = _self.maxY - _self.minY + 1; var date_yy = dateArr.yy % passY + _self.minY; var date_mm = dateArr.mm + 1; var date_dd = dateArr.dd + 1; var objDate = calendarConvert(0, date_yy, date_mm, date_dd);//返回转换对象 var isRm = LunarCal[objDate.yy - _self.minY].Intercalation ? LunarCal[objDate.yy - _self.minY].Intercalation : 0;//判断是不是闰年 if (objDate.mm < 0) objDate.mm = -objDate.mm + 1;//返回的负数为 闰年 else //闰年月份+1重复选择,位置才正确 if (isRm && (objDate.mm - 1) >= isRm) objDate.mm = objDate.mm + 1; //console.log(objDate.yy - _self.minY+‘_‘+isRm+‘_‘+objDate.mm); _self.gearDate.querySelector(".date_yy").setAttribute("val", objDate.yy - _self.minY); _self.gearDate.querySelector(".date_mm").setAttribute("val", objDate.mm - 1); _self.gearDate.querySelector(".date_dd").setAttribute("val", objDate.dd - 1); else _self.type = 0; var gongli = _self.gearDate.querySelector(".lcalendar_gongli"); gongli.className = gongli.className.replace(/active/, "").replace(/(^\s*)|(\s*$)/g, "") + ‘ active‘; setDateGearTooth(); //重置日期节点个数+设置日期 function setDateGearTooth() var passY = _self.maxY - _self.minY + 1; var date_yy = _self.gearDate.querySelector(".date_yy"); var itemStr = ""; if (date_yy && date_yy.getAttribute("val")) //得到年份的值 var yyVal = parseInt(date_yy.getAttribute("val")); //p 当前节点前后需要展示的节点个数 for (var p = 0; p <= passY - 1; p++) itemStr += "<div class=‘tooth‘>" + (_self.minY + p) + "</div>"; date_yy.innerHTML = itemStr; var top = Math.floor(parseFloat(date_yy.getAttribute(‘top‘))); if (!isNaN(top)) top % 2 == 0 ? (top = top) : (top = top + 1); top > 6 && (top = 6); var minTop = 6 - (passY - 1) * 2; top < minTop && (top = minTop); date_yy.style["transform"] = ‘translate(0,‘ + top + ‘em)‘; date_yy.style["-webkit-transform"] = ‘translate(0,‘ + top + ‘em)‘; date_yy.style["-moz-transform"] = ‘translate(0,‘ + top + ‘em)‘; date_yy.style["-ms-transform"] = ‘translate(0,‘ + top + ‘em)‘; date_yy.style["-o-transform"] = ‘translate(0,‘ + top + ‘em)‘; date_yy.setAttribute(‘top‘, top + ‘em‘); yyVal = Math.abs(top - 6) / 2; date_yy.setAttribute("val", yyVal); else date_yy.style["transform"] = ‘translate(0,‘ + (6 - yyVal * 2) + ‘em)‘; date_yy.style["-webkit-transform"] = ‘translate(0,‘ + (6 - yyVal * 2) + ‘em)‘; date_yy.style["-moz-transform"] = ‘translate(0,‘ + (6 - yyVal * 2) + ‘em)‘; date_yy.style["-ms-transform"] = ‘translate(0,‘ + (6 - yyVal * 2) + ‘em)‘; date_yy.style["-o-transform"] = ‘translate(0,‘ + (6 - yyVal * 2) + ‘em)‘; date_yy.setAttribute(‘top‘, (6 - yyVal * 2) + ‘em‘); else return; var date_mm = _self.gearDate.querySelector(".date_mm"); if (date_mm && date_mm.getAttribute("val")) itemStr = ""; //得到月份的值 var mmVal = parseInt(date_mm.getAttribute("val")); // 判断否有闰月 var rmNum = LunarCal[yyVal].Intercalation ? LunarCal[yyVal].Intercalation : 0; if (rmNum && _self.type) var maxM = 12; else var maxM = 11; var minM = 0; //当年份到达最大值 if (yyVal == passY - 1) if (_self.type) maxM = _self.maxM - 2; else maxM = _self.maxM - 1; // maxM = _self.maxM - 1; //当年份到达最小值 if (yyVal == 0) if (_self.type) minM = _self.minM - 1; else minM = _self.minM; // minM = _self.minM - 1; //p 当前节点前后需要展示的节点个数 for (var p = 0; p < maxM - minM + 1; p++) var strVal = minM + p + 1; // 农历 if (_self.type) // 闰月 if (rmNum && rmNum == p) strVal = getChinese(‘rm‘, strVal - 1); else if (rmNum && rmNum < p) strVal = getChinese(‘mm‘, strVal - 1); else strVal = getChinese(‘mm‘, strVal); if (_self.type == 0) itemStr += "<div class=‘tooth‘>" + strVal + "月</div>"; else itemStr += "<div class=‘tooth‘>" + strVal + "</div>"; date_mm.innerHTML = itemStr; if (mmVal > maxM) mmVal = maxM; date_mm.setAttribute("val", mmVal); else if (mmVal < minM) mmVal = maxM; date_mm.setAttribute("val", mmVal); date_mm.style["transform"] = ‘translate(0,‘ + (6 - (mmVal - minM) * 2) + ‘em)‘; date_mm.style["-webkit-transform"] = ‘translate(0,‘ + (6 - (mmVal - minM) * 2) + ‘em)‘; date_mm.style["-moz-transform"] = ‘translate(0,‘ + (6 - (mmVal - minM) * 2) + ‘em)‘; date_mm.style["-ms-transform"] = ‘translate(0,‘ + (6 - (mmVal - minM) * 2) + ‘em)‘; date_mm.style["-o-transform"] = ‘translate(0,‘ + (6 - (mmVal - minM) * 2) + ‘em)‘; date_mm.setAttribute(‘top‘, 6 - (mmVal - minM) * 2 + ‘em‘); else return; var date_dd = _self.gearDate.querySelector(".date_dd"); if (date_dd && date_dd.getAttribute("val")) itemStr = ""; //得到日期的值 var ddVal = parseInt(date_dd.getAttribute("val")); //返回月份的天数 var maxMonthDays = calcDays(yyVal, mmVal); // console.log(yyVal+‘,‘+mmVal+‘,‘+maxMonthDays); //p 当前节点前后需要展示的节点个数 var maxD = maxMonthDays - 1; var minD = 0; //当年份月份到达最大值 if (yyVal == passY - 1 && 11 == mmVal + 1) if (_self.type) maxD = _self.maxD - 7; else maxD = _self.maxD - 2; // maxD = _self.maxD - 1; //当年、月到达最小值 if (yyVal == 0 && 2 == mmVal + 1) if (_self.type) minD = _self.minD - 1; else minD = _self.minD + 6; for (var p = 0; p < maxD - minD + 1; p++) var strVal = _self.type ? getChinese(‘dd‘, minD + p + 1) : (minD + p + 1); if (_self.type == 0) itemStr += "<div class=‘tooth‘>" + strVal + "日</div>"; else itemStr += "<div class=‘tooth‘>" + strVal + "</div>"; date_dd.innerHTML = itemStr; if (ddVal > maxD) ddVal = maxD; date_dd.setAttribute("val", ddVal); else if (ddVal < minD) ddVal = minD; date_dd.setAttribute("val", ddVal); date_dd.style["transform"] = ‘translate(0,‘ + (6 - (ddVal - minD) * 2) + ‘em)‘; date_dd.style["-webkit-transform"] = ‘translate(0,‘ + (6 - (ddVal - minD) * 2) + ‘em)‘; date_dd.style["-moz-transform"] = ‘translate(0,‘ + (6 - (ddVal - minD) * 2) + ‘em)‘; date_dd.style["-ms-transform"] = ‘translate(0,‘ + (6 - (ddVal - minD) * 2) + ‘em)‘; date_dd.style["-o-transform"] = ‘translate(0,‘ + (6 - (ddVal - minD) * 2) + ‘em)‘; date_dd.setAttribute(‘top‘, 6 - (ddVal - minD) * 2 + ‘em‘); else return; var date_hh = _self.gearDate.querySelector(".date_hh"); if (date_hh && date_hh.getAttribute("val")) var hhVal = parseInt(date_hh.getAttribute("val")); itemStr = "<div class=‘tooth‘>未知</div>";//"<div class=‘tooth‘>未知</div>"; for (var p = 0; p < 24; p++) var strVal = _self.type ? getChinese(‘hh‘, p) : p; itemStr += "<div class=‘tooth‘>" + strVal + "时</div>"; date_hh.innerHTML = itemStr; date_hh.style["transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_hh.style["-webkit-transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_hh.style["-moz-transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_hh.style["-ms-transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_hh.style["-o-transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_hh.setAttribute(‘top‘, (6 - hhVal * 2) + ‘em‘); //console.log("hhVal:"+hhVal); //分钟数初始化 var date_min = _self.gearDate.querySelector(".date_min"); if (date_min && date_min.getAttribute("val")) var hhVal = parseInt(date_min.getAttribute("val")); itemStr = "<div class=‘tooth‘>未知</div>"; //公历农历显示一样 for (var p = 0; p < 60; p++) itemStr += "<div class=‘tooth‘>" + p + "分</div>"; date_min.innerHTML = itemStr; date_min.style["transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_min.style["-webkit-transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_min.style["-moz-transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_min.style["-ms-transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_min.style["-o-transform"] = ‘translate(0,‘ + (6 - hhVal * 2) + ‘em)‘; date_min.setAttribute(‘top‘, (6 - hhVal * 2) + ‘em‘); getCalendarDate();//设置日期 //求月份最大天数 function calcDays(year, month) // 农历查询数据 if (_self.type == 1) if (LunarCal[year].MonthDays[month]) return 30; else return 29; else if (month == 1) year += _self.minY; if ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0 && year % 4000 != 0)) return 29; else return 28; else if (month == 3 || month == 5 || month == 8 || month == 10) return 30; else return 31; // 中文转换,type:rm闰月,mm月份,dd日期,num值 function getChinese(type, num) var rmArr = [‘闰正月‘, ‘闰二月‘, ‘闰三月‘, ‘闰四月‘, ‘闰五月‘, ‘闰六月‘, ‘闰七月‘, ‘闰八月‘, ‘闰九月‘, ‘闰十月‘, ‘闰冬月‘, ‘闰腊月‘]; var mmArr = [‘正月‘, ‘二月‘, ‘三月‘, ‘四月‘, ‘五月‘, ‘六月‘, ‘七月‘, ‘八月‘, ‘九月‘, ‘十月‘, ‘十一月‘, ‘十二月‘]; var ddArr = [‘初一‘, ‘初二‘, ‘初三‘, ‘初四‘, ‘初五‘, ‘初六‘, ‘初七‘, ‘初八‘, ‘初九‘, ‘初十‘, ‘十一‘, ‘十二‘, ‘十三‘, ‘十四‘, ‘十五‘, ‘十六‘, ‘十七‘, ‘十八‘, ‘十九‘, ‘二十‘, ‘廿一‘, ‘廿二‘, ‘廿三‘, ‘廿四‘, ‘廿五‘, ‘廿六‘, ‘廿七‘, ‘廿八‘, ‘廿九‘, ‘三十‘, ‘三十一‘]; var hhArr = [‘0子‘, ‘1丑‘, ‘2丑‘, ‘3寅‘, ‘4寅‘, ‘5卯‘, ‘6卯‘, ‘7辰‘, ‘8辰‘, ‘9巳‘, ‘10巳‘, ‘11午‘, ‘12午‘, ‘13未‘, ‘14未‘, ‘15申‘, ‘16申‘, ‘17酉‘, ‘18酉‘, ‘19戌‘, ‘20戌‘, ‘21亥‘, ‘22亥‘, ‘23子‘]; if (type == ‘rm‘) return rmArr[num - 1]; if (type == ‘mm‘) return mmArr[num - 1]; if (type == ‘dd‘) return ddArr[num - 1]; if (type == ‘hh‘) return hhArr[num]; /** * 公历农历转换 * M=0公历到农历,M=1农历到公历 * date_yy:年 * date_mm:月,闰月为 负数 * date_dd:日 */ function calendarConvert(M, date_yy, date_mm, date_dd) var year = date_yy; var month = date_mm; var date = date_dd; var FIRSTYEAR = 1940;//最小年份 var LASTYEAR = 2020;//最大年份 //西曆年每月之日數 var SolarCal = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]; //西曆年每月之累積日數, 平年與閏年 var SolarDays = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365, 396, 0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335, 366, 397]; //公历转农历 if (M == 0) var SolarYear = parseInt(year); var SolarMonth = parseInt(month); var SolarDate = parseInt(date); var sm = SolarMonth - 1; var leap = GetLeap(SolarYear); var d = (sm == 1) ? leap + 28 : SolarCal[sm]; var y = SolarYear - FIRSTYEAR; var acc = SolarDays[leap * 14 + sm] + SolarDate; var kc = acc + LunarCal[y].BaseKanChih; var Age = kc % 60; Age = (Age < 22) ? 22 - Age : 82 - Age; Age = Age + 3; if (Age < 10) Age = Age + 60; if (acc <= LunarCal[y].BaseDays) y--; var LunarYear = SolarYear - 1; leap = GetLeap(LunarYear); sm += 12; acc = SolarDays[leap * 14 + sm] + SolarDate; else var LunarYear = SolarYear; var l1 = LunarCal[y].BaseDays; for (i = 0; i < 13; i++) var l2 = l1 + LunarCal[y].MonthDays[i] + 29; if (acc <= l2) break; l1 = l2; var LunarMonth = i + 1; var LunarDate = acc - l1; var im = LunarCal[y].Intercalation; if (im != 0 && LunarMonth > im) LunarMonth--; if (LunarMonth == im) LunarMonth = -im; if (LunarMonth > 12) LunarMonth -= 12; return yy: LunarYear, mm: LunarMonth, dd: LunarDate ; /* 农历转公历 */ else var LunarYear = parseInt(year); var LunarMonth = parseInt(month); var LunarDate = parseInt(date); var y = LunarYear - FIRSTYEAR; var im = LunarCal[y].Intercalation; var lm = LunarMonth; if (im != 0) if (lm > im) lm++; else if (lm == -im) lm = im + 1; lm--; var acc = 0; for (var i = 0; i < lm; i++) acc += LunarCal[y].MonthDays[i] + 29; acc += LunarCal[y].BaseDays + LunarDate; var leap = GetLeap(LunarYear); for (var i = 13; i >= 0; i--) if (acc > SolarDays[leap * 14 + i]) break; var SolarDate = acc - SolarDays[leap * 14 + i]; if (i <= 11) var SolarYear = LunarYear; var SolarMonth = i + 1; else var SolarYear = LunarYear + 1; var SolarMonth = i - 11; // return SolarYear + "-" + SolarMonth + "-" + SolarDate; return yy: SolarYear, mm: SolarMonth, dd: SolarDate ; /* 闰年, 返回 0 平年, 1 闰年 */ function GetLeap(year) if (year % 400 == 0) return 1; else if (year % 100 == 0) return 0; else if (year % 4 == 0) return 1; else return 0; // 农历对象数据处理 function tagLunarCal(d, i, w, k, m1, m2, m3, m4, m5, m6, m7, m8, m9, m10, m11, m12, m13) this.BaseDays = d; /* 1 月 1 日到正月初一的累计日 */ this.Intercalation = i; /* 闰月月份. 0==此年沒有闰月 */ this.BaseWeekday = w; /* 此年 1 月 1 日为星期减 1 */ this.BaseKanChih = k; /* 此年 1 月 1 日之干支序号减 1 */ this.MonthDays = [m1, m2, m3, m4, m5, m6, m7, m8, m9, m10, m11, m12, m13]; /* 此农历年每月之大小, 0==小月(29日), 1==大月(30日) */ // PC滑动鼠标滚轮处理 function gearMouseRolling(e) var e = e || event; var dir = true; if (e.wheelDelta) dir = e.wheelDelta > 0 ? true : false; //ie和chrome else dir = e.detail < 0 ? true : false;//firefox //dir:true向上滚动,false向下滚动 var moveDir = dir ? 21 : -21; // 移动前 e.preventDefault(); var target = e.target; while (true) if (!target.classList.contains("gear")) target = target.parentElement; else break clearInterval(target["int_" + target.id]); target["old_" + target.id] = 0; target["o_t_" + target.id] = (new Date()).getTime(); var top = target.getAttribute(‘top‘); if (top) target["o_d_" + target.id] = parseFloat(top.replace(/em/g, "")); else target["o_d_" + target.id] = 0; // 移动中 target["new_" + target.id] = moveDir; target["n_t_" + target.id] = (new Date()).getTime() + 360; var f = (target["new_" + target.id] - target["old_" + target.id]) * 18 / 370; target["pos_" + target.id] = target["o_d_" + target.id] + f; target.setAttribute(‘top‘, target["pos_" + target.id] + ‘em‘); // 移动后 var flag = (target["new_" + target.id] - target["old_" + target.id]) / (target["n_t_" + target.id] - target["o_t_" + target.id]); if (Math.abs(flag) <= 0.2) target["spd_" + target.id] = (flag < 0 ? -0.08 : 0.08); else if (Math.abs(flag) <= 0.5) target["spd_" + target.id] = (flag < 0 ? -0.16 : 0.16); else target["spd_" + target.id] = flag / 2; if (!target["pos_" + target.id]) target["pos_" + target.id] = 0; if (e.preventDefault) e.preventDefault(); rollGear(target); return false; // PC滑动鼠标处理 function gearMouseSlide(e) e.preventDefault(); var target = e.target; var targetPc = target; var mousedownTip = false;//鼠标滑动锁 while (true) if (!target.classList.contains("gear")) target = target.parentElement; else break clearInterval(target["int_" + target.id]); target["old_" + target.id] = e.screenY; target["o_t_" + target.id] = (new Date()).getTime(); var top = target.getAttribute(‘top‘); if (top) target["o_d_" + target.id] = parseFloat(top.replace(/em/g, "")); else target["o_d_" + target.id] = 0; document.onmousemove = function (e) mousedownTip = true;//鼠标滑动锁 e = e || window.event; e.preventDefault(); var target = targetPc;//鼠标兼容处理 while (true) if (!target.classList.contains("gear")) target = target.parentElement; else break target["new_" + target.id] = e.screenY; target["n_t_" + target.id] = (new Date()).getTime(); var f = (target["new_" + target.id] - target["old_" + target.id]) * 18 / 370; target["pos_" + target.id] = target["o_d_" + target.id] + f; target.style["transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.style["-webkit-transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.style["-moz-transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.style["-ms-transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.style["-o-transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.setAttribute(‘top‘, target["pos_" + target.id] + ‘em‘); ; // 释放鼠标 document.onmouseup = function (e) //阻止点击 if (!mousedownTip) document.onmousemove = null; document.onmouseup = null; return false; e = e || window.event; e.preventDefault(); var target = targetPc;//鼠标兼容处理 while (true) if (!target.classList.contains("gear")) target = target.parentElement; else break; var flag = (target["new_" + target.id] - target["old_" + target.id]) / (target["n_t_" + target.id] - target["o_t_" + target.id]); if (Math.abs(flag) <= 0.2) target["spd_" + target.id] = (flag < 0 ? -0.08 : 0.08); else if (Math.abs(flag) <= 0.5) target["spd_" + target.id] = (flag < 0 ? -0.16 : 0.16); else target["spd_" + target.id] = flag / 2; if (!target["pos_" + target.id]) target["pos_" + target.id] = 0; rollGear(target); document.onmousemove = null; document.onmouseup = null; //触摸开始 function gearTouchStart(e) e.preventDefault(); var target = e.target; target[‘touchTip‘] = false;//滑动锁 while (true) if (!target.classList.contains("gear")) target = target.parentElement; else break clearInterval(target["int_" + target.id]); target["old_" + target.id] = e.targetTouches[0].screenY; target["o_t_" + target.id] = (new Date()).getTime(); var top = target.getAttribute(‘top‘); if (top) target["o_d_" + target.id] = parseFloat(top.replace(/em/g, "")); else target["o_d_" + target.id] = 0; //手指移动 function gearTouchMove(e) e.preventDefault(); var target = e.target; target[‘touchTip‘] = true;//滑动锁 while (true) if (!target.classList.contains("gear")) target = target.parentElement; else break target["new_" + target.id] = e.targetTouches[0].screenY; target["n_t_" + target.id] = (new Date()).getTime(); var f = (target["new_" + target.id] - target["old_" + target.id]) * 18 / 370; target["pos_" + target.id] = target["o_d_" + target.id] + f; target.style["transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.style["-webkit-transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.style["-moz-transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.style["-ms-transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.style["-o-transform"] = ‘translate(0,‘ + target["pos_" + target.id] + ‘em)‘; target.setAttribute(‘top‘, target["pos_" + target.id] + ‘em‘); //离开屏幕 function gearTouchEnd(e) e.preventDefault(); var target = e.target; if (!target[‘touchTip‘]) return false; while (true) if (!target.classList.contains("gear")) target = target.parentElement; else break; var flag = (target["new_" + target.id] - target["old_" + target.id]) / (target["n_t_" + target.id] - target["o_t_" + target.id]); if (Math.abs(flag) <= 0.2) target["spd_" + target.id] = (flag < 0 ? -0.08 : 0.08); else if (Math.abs(flag) <= 0.5) target["spd_" + target.id] = (flag < 0 ? -0.16 : 0.16); else target["spd_" + target.id] = flag / 2; if (!target["pos_" + target.id]) target["pos_" + target.id] = 0; rollGear(target); //缓动效果 function rollGear(target) var d = 0; var stopGear = false; var passY = _self.maxY - _self.minY + 1; clearInterval(target["int_" + target.id]); target["int_" + target.id] = setInterval(function () var pos = target["pos_" + target.id]; var speed = target["spd_" + target.id] * Math.exp(-0.03 * d); pos += speed; if (Math.abs(speed) > 0.1) else speed = 0.1; var b = Math.round(pos / 2) * 2; if (Math.abs(pos - b) < 0.02) stopGear = true; else if (pos > b) pos -= speed else pos += speed if (pos > 6) pos = 6; stopGear = true; switch (target.getAttribute(‘data-datetype‘)) case "date_yy": var minTop = 6 - (passY - 1) * 2; if (pos < minTop) pos = minTop; stopGear = true; if (stopGear) var gearVal = Math.abs(pos - 6) / 2; setGear(target, gearVal); clearInterval(target["int_" + target.id]); break; case "date_mm": var date_yy = _self.gearDate.querySelector(".date_yy"); //得到年份的值 var yyVal = parseInt(date_yy.getAttribute("val")); // 判断否有闰月 var rmNum = LunarCal[yyVal].Intercalation ? LunarCal[yyVal].Intercalation : 0; if (rmNum && _self.type) var maxM = 12; else var maxM = 11; var minM = 0; //当年份到达最大值 if (yyVal == passY - 1) if (_self.type) maxM = _self.maxM - 2; else maxM = _self.maxM - 1; // maxM = _self.maxM - 1; //当年份到达最小值 if (yyVal == 0) if (_self.type) minM = _self.minM - 1; else minM = _self.minM; // minM = _self.minM - 1; var minTop = 6 - (maxM - minM) * 2; if (pos < minTop) pos = minTop; stopGear = true; if (stopGear) var gearVal = Math.abs(pos - 6) / 2 + minM; setGear(target, gearVal); clearInterval(target["int_" + target.id]); break; case "date_dd": var date_yy = _self.gearDate.querySelector(".date_yy"); var date_mm = _self.gearDate.querySelector(".date_mm"); //得到年份的值 var yyVal = parseInt(date_yy.getAttribute("val")); //得到月份的值 var mmVal = parseInt(date_mm.getAttribute("val")); //返回月份的天数 var maxMonthDays = calcDays(yyVal, mmVal); var maxD = maxMonthDays - 1; var minD = 0; //当年份月份到达最大值 if (yyVal == passY - 1 && 11 == mmVal + 1) if (_self.type) maxD = _self.maxD - 7; else maxD = _self.maxD - 2; // maxD = _self.maxD - 1; //当年、月到达最小值 if (yyVal == 0 && 2 == mmVal + 1) if (_self.type) minD = _self.minD - 1; else minD = _self.minD + 6; // minD = _self.minD - 1; var minTop = 6 - (maxD - minD) * 2; if (pos < minTop) pos = minTop; stopGear = true; if (stopGear) var gearVal = Math.abs(pos - 6) / 2 + minD; setGear(target, gearVal); clearInterval(target["int_" + target.id]); break; case "date_hh": var maxHH = 25;//控制时辰滑动选择的 var minTop = 6 - (maxHH - 1) * 2; if (pos < minTop) pos = minTop; stopGear = true; if (stopGear) var gearVal = Math.abs(pos - 6) / 2; setGear(target, gearVal); clearInterval(target["int_" + target.id]); break; case "date_min": var maxMinute = 61; //控制分钟滑动选择的 var minTop = 6 - (maxMinute - 1) * 2; if (pos < minTop) pos = minTop; stopGear = true; if (stopGear) var gearVal = Math.abs(pos - 6) / 2; setGear(target, gearVal); clearInterval(target["int_" + target.id]); break; default: target["pos_" + target.id] = pos; target.style["transform"] = ‘translate(0,‘ + pos + ‘em)‘; target.style["-webkit-transform"] = ‘translate(0,‘ + pos + ‘em)‘; target.style["-moz-transform"] = ‘translate(0,‘ + pos + ‘em)‘; target.style["-ms-transform"] = ‘translate(0,‘ + pos + ‘em)‘; target.style["-o-transform"] = ‘translate(0,‘ + pos + ‘em)‘; target.setAttribute(‘top‘, pos + ‘em‘); d++; , 6); //控制插件滚动后停留的值 function setGear(target, val) val = Math.round(val); target.setAttribute("val", val); setDateGearTooth(); //取消 function closeMobileCalendar(e) e.preventDefault(); if (!window.CustomEvent) var evt = new CustomEvent(‘input‘); _self.trigger.dispatchEvent(evt); document.body.removeChild(_self.gearDate); //_self.trigger.removeAttribute(‘data-history‘); //document.getElementById(_self.trigger.getAttribute(‘data-toid-show‘)).style[‘display‘] = "none"; //日期确认 function finishMobileDate(e) var d = getCalendarDate(); _self.trigger.setAttribute(‘data-date‘, d.yy + "-" + d.mm + "-" + d.dd); _self.trigger.setAttribute(‘data-hour‘, d.hh); _self.trigger.setAttribute(‘data-minute‘, d.min); var inputId = _self.trigger.getAttribute(‘data-toid-date‘); var hourId = _self.trigger.getAttribute(‘data-toid-hour‘); var minuteId = _self.trigger.getAttribute(‘data-toid-minute‘); var calendarId = _self.trigger.getAttribute(‘data-toid-calendar‘);//检查存储历法是否 if (inputId) document.getElementById(inputId).value = d.yy + "-" + d.mm + "-" + d.dd; if (hourId) document.getElementById(hourId).value = d.hh < 0 ? ‘‘ : d.hh; if (minuteId) document.getElementById(minuteId).value = d.min < 0 ? ‘‘ : d.min; if (calendarId) document.getElementById(calendarId).value = d.lifa; var hourStr = ‘‘, minuteStr = ‘‘; if (_self.type) var mmChina = d._mm < 0 ? getChinese(‘rm‘, -d._mm) : getChinese(‘mm‘, d._mm); if (hourId) if (d.hh < 0) hourStr = "未知"; else hourStr = getChinese(‘hh‘, d.hh) + ‘时‘; if (minuteId) if (d.min < 0) minuteStr = "未知"; else minuteStr = d.min + ‘分‘; _self.trigger.value = "农(阴)历:" + d._yy + "年" + mmChina + ‘‘ + getChinese(‘dd‘, d._dd) + ‘ ‘ + (hourStr == "未知" ? "" : hourStr + (minuteStr == "未知" ? "" : minuteStr)); else if (hourId) if (d.hh < 0) hourStr = "未知"; else hourStr = d.hh + ‘时‘; if (minuteId) if (d.min < 0) minuteStr = "未知"; else minuteStr = d.min + ‘分‘; _self.trigger.value = "公(阳)历:" + d.yy + "年" + d.mm + "月" + d.dd + ‘日 ‘ + (hourStr == "未知" ? "" : hourStr + (minuteStr == "未知" ? "" : minuteStr)); //确认时间填充文本 //document.querySelector(‘.timeOne‘).innerHTML = _self.trigger.value; // document.querySelector(‘.timeOne‘).style[‘display‘]="block"; // document.querySelector(‘.xiugaizz‘).style[‘display‘]="block"; //document.querySelector(‘.xiugaizz‘).setAttribute(‘data-show‘, ‘1‘); closeMobileCalendar(e); //设置顶部日期+返回对象 _yy 农历年 yy公历年 function getCalendarDate() var passY = _self.maxY - _self.minY + 1; var val_yy = parseInt(Math.round(_self.gearDate.querySelector(".date_yy").getAttribute("val"))); var date_yy = val_yy % passY + _self.minY; var date_mm = parseInt(Math.round(_self.gearDate.querySelector(".date_mm").getAttribute("val"))) + 1; //判断从未知开始 var date_dd = parseInt(Math.round(_self.gearDate.querySelector(".date_dd").getAttribute("val"))) + 1; // 判断是否启用时辰 var hour_on = _self.gearDate.querySelector(".date_hh") ? 1 : 0; if (hour_on) var date_hh = parseInt(Math.round(_self.gearDate.querySelector(".date_hh").getAttribute("val"))) - 1; // 判断是否启用分钟 var minute_on = _self.gearDate.querySelector(".date_min") ? 1 : 0; if (minute_on) var date_min = parseInt(Math.round(_self.gearDate.querySelector(".date_min").getAttribute("val"))) - 1; // 判断否有闰月 var rmNum = LunarCal[val_yy].Intercalation ? LunarCal[val_yy].Intercalation : 0; if (_self.type && rmNum) if (rmNum == (date_mm - 1)) date_mm = -(date_mm - 1); else if (rmNum < (date_mm - 1)) date_mm = date_mm - 1; else date_mm = date_mm; var objDate = calendarConvert(_self.type, date_yy, date_mm, date_dd); var info = _self.gearDate.querySelector(".lcalendar_info"); if (_self.type) //农历 _self.trigger.setAttribute("data-type", 1); var mmChina = date_mm < 0 ? getChinese(‘rm‘, -date_mm) : getChinese(‘mm‘, date_mm); var hhStr = "", minStr = ""; if (hour_on) if (date_hh < 0) hhStr = "未知"; else hhStr = getChinese(‘hh‘, date_hh) + ‘时‘; if (minute_on) if (date_min < 0) minStr = "未知"; else minStr = date_min + ‘分‘; info.innerHTML = ‘农历:‘ + date_yy + ‘年‘ + mmChina + ‘‘ + getChinese(‘dd‘, date_dd) + ‘ ‘ + hhStr + (minStr ? minStr : ""); return yy: objDate.yy, mm: objDate.mm, dd: objDate.dd, _yy: date_yy, _mm: date_mm, _dd: date_dd, hh: date_hh, min: date_min, lifa: 1 else //公历 _self.trigger.setAttribute("data-type", 0); var hhStr = "", minStr = ""; if (hour_on) if (date_hh < 0) hhStr = "未知"; else hhStr = date_hh + ‘时‘; if (minute_on) if (date_min < 0) minStr = "未知"; else minStr = date_min + ‘分‘; info.innerHTML = ‘公历:‘ + date_yy + ‘年‘ + date_mm + ‘月‘ + date_dd + ‘日‘ + ‘ ‘ + hhStr + (minStr ? minStr : ""); return _yy: objDate.yy, _mm: objDate.mm, _dd: objDate.dd, yy: date_yy, mm: date_mm, dd: date_dd, hh: date_hh, min: date_min, lifa: 0 /* * 2018-8-6新增 */ function popupShow(e) var d = getCalendarDate(); var inputId = _self.trigger.getAttribute(‘data-toid-date‘); var hourId = _self.trigger.getAttribute(‘data-toid-hour‘); var minuteId = _self.trigger.getAttribute(‘data-toid-minute‘); var calendarId = _self.trigger.getAttribute(‘data-toid-calendar‘);//检查存储历法是否 if (inputId) document.getElementById(inputId).value = d.yy + "-" + d.mm + "-" + d.dd; if (hourId) document.getElementById(hourId).value = d.hh < 0 ? ‘‘ : d.hh; if (minuteId) document.getElementById(minuteId).value = d.min < 0 ? ‘‘ : d.min; if (calendarId) document.getElementById(calendarId).value = d.lifa; var hourStr = ‘‘, minuteStr = ‘‘; if (_self.type) var mmChina = d._mm < 0 ? getChinese(‘rm‘, -d._mm) : getChinese(‘mm‘, d._mm); if (hourId) if (d.hh < 0) hourStr = "未知"; else hourStr = getChinese(‘hh‘, d.hh) + ‘时‘; if (minuteId) if (d.min < 0) minuteStr = "未知"; else minuteStr = d.min + ‘分‘; _self.trigger.setAttribute(‘data-history‘, "农(阴)历:" + d._yy + "年" + mmChina + ‘‘ + getChinese(‘dd‘, d._dd) + ‘ ‘ + (hourStr == "未知" ? "" : hourStr + (minuteStr == "未知" ? "" : minuteStr))); else if (hourId) if (d.hh < 0) hourStr = "未知"; else hourStr = d.hh + ‘时‘; if (minuteId) if (d.min < 0) minuteStr = "未知"; else minuteStr = d.min + ‘分‘; _self.trigger.setAttribute(‘data-history‘, "公(阳)历:" + d.yy + "年" + d.mm + "月" + d.dd + ‘日 ‘ + (hourStr == "未知" ? "" : hourStr + (minuteStr == "未知" ? "" : minuteStr))); // closeMobileCalendar(e); if (_self.trigger.getAttribute(‘data-toid-show‘)) document.getElementById(_self.trigger.getAttribute(‘data-toid-show‘)).style[‘display‘] = ‘block‘; document.querySelector(‘.TipsTimeTxt‘).innerHTML = _self.trigger.getAttribute(‘data-history‘); // 判断移动端 var isMove = false; var startTime = 0; if (‘ontouchstart‘ in window) // 判断移动的点击事件tap操作 _self.trigger.addEventListener(‘touchstart‘, function (e) startTime = Date.now(); ); _self.trigger.addEventListener(‘touchmove‘, function (e) isMove = true; ); _self.trigger.addEventListener(‘touchend‘, function (e) /*判读 是否满足tap 的要求 一般要求tap的响应时间150*/ if (!isMove && (Date.now() - startTime) < 150) e.preventDefault(); popupDate(); /*重置 参数*/ isMove = false; startTime = 0; ); else _self.trigger.addEventListener(‘click‘, function () popupDate(); ) return datePicker; )()
第一大段代码是demo,第二、第三段是css、js文件,你可以自行打包。代码不做多余解释,自己看。demo已经很明白了!如果想要修改最大显示年,修改js中大约63行的2020即可。
* ruiDatePicker 农历公历-日历控件
* 版本:1.0
* 作者:羯瑞
* 邮箱:410232098@qq.com
* 创建于:2016-12-31
* 修改:于2018-04-10 下午 永恒的微笑修改
* 更新:增加了第三种模式:添加了分钟选项
* 使用方法:
1、只有年月日:data-toid-date="保存年月日隐藏id"
2、年月日时data-toid-date="保存年月日隐藏id" data-toid-hour="保存小时隐藏域id"
3、年月日时分data-toid-date="保存年月日隐藏id" data-toid-hour="保存小时隐藏域id" data-toid-minute="保存分钟隐藏域id"
返回值绑定:历法:data-toid-calendar="历法id"
以上是关于一款很好用的 Vue audio 插件 vue-audio-better的主要内容,如果未能解决你的问题,请参考以下文章