日期多选插件Kalendae.js
2017-10-16 10:42
387 查看
Kalendae.js一句话介绍
Kalendae.js是一款强大的日期多控件(插件),支持日期的单选、日期的多选、日期的范围选择 案例
Kalendae.js如何使用
下载
(Github下载|csdn下载)下载Kalendae.js相关的资源,解压后将build目录下的js和css拷贝到项目相应的资源文件夹下面,在需要使用日期多选的页面引入js和css就行了: <link rel="stylesheet" href="./build/kalendae.css" type="text/css"> <script type='text/javascript' src='./build/kalendae.standalone.js'></script> <!-- 这里不引入min.js是因为在后面要修改js -->
在页面使用:新建一个demo.html
①直接使用:<!-- 单选 --> <div class="auto-kal"></div> <!-- 多选 --> <div class="auto-kal" data-kal="mode:'multiple'"></div>
完整代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <link rel="stylesheet" href="./build/kalendae.css" type="text/css"> <script type='text/javascript' src='./build/kalendae.standalone.js'></script> <title>KalendaeDemo</title> </head> <body> <p>1直接展示(单选)</p> <div class="auto-kal"></div> <p>1.1直接展示(多选)</p> <div class="auto-kal" data-kal="mode:'multiple'"></div> </body> </html>
②输入框使用
<!-- 单选 --> <input type="text" class="auto-kal"> <!-- 多选 --> <input type="text" class="auto-kal" data-kal="mode:'multiple'">
完整代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <link rel="stylesheet" href="./build/kalendae.css" type="text/css"> <script type='text/javascript' src='./build/kalendae.standalone.js'></script> <title>KalendaeDemo</title> </head> <body> <p>2输入框使用(单选):</p> <input type="text" class="auto-kal"> <p>2输入框使用(多选):</p> <input type="text" class="auto-kal" data-kal="mode:'multiple'" style="width: 100%;"> </body> </html>
demo.html完整代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <link rel="stylesheet" href="./build/kalendae.css" type="text/css"> <script type='text/javascript' src='./build/kalendae.standalone.js'></script> <title>KalendaeDemo</title> </head> <body> <p>1直接展示(单选)</p> <div class="auto-kal"></div> <p>1.1直接展示(多选)</p> <div class="auto-kal" data-kal="mode:'multiple'"></div> <p>2输入框使用(单选):</p> <input type="text" class="auto-kal"> <p>2输入框使用(多选):</p> <input type="text" class="auto-kal" data-kal="mode:'multiple'" style="width: 100%;"> </body> </html>
显示效果:
Kalendae.js的个性化配置
日期中文显示
默认显示的样式是英文的,用户不友好,可以在kalendae.standalone.js里面进行编辑,设置Locale.prototype
修改月份显示效果:
/*修改_months属性和_monthsShort属性*/ _months : '1月_2月_3月_4月_5月_6月_7月_8月_9月_10月_11月_12月'.split('_') _monthsShort : '1月_2月_3月_4月_5月_6月_7月_8月_9月_10月_11月_12月'.split('_')
最终是这样子的:
/*_months : 'January_February_March_April_May_June_July_August_September_October_November_December'.split('_'),*/ _months : '1月_2月_3月_4月_5月_6月_7月_8月_9月_10月_11月_12月'.split('_'), months : function (m) { return this._months[m.month()]; }, /*_monthsShort : 'Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec'.split('_'),*/ _monthsShort : '1月_2月_3月_4月_5月_6月_7月_8月_9月_10月_11月_12月'.split('_'), monthsShort : function (m) { return this._monthsShort[m.month()]; },
修改“星期”显示效果:
修改_weekdays 、_weekdaysShort 和_weekdaysMin 最终代码:
//星期显示样式 _weekdays : '星期日_星期一_星期二_星期三_星期四_星期五_星期六'.split('_'), weekdays : function (m) { return this._weekdays[m.day()]; }, _weekdaysShort : '周日_周一_周二_周三_周四_周五_周六'.split('_'), weekdaysShort : function (m) { return this._weekdaysShort[m.day()]; }, _weekdaysMin : '日_一_二_三_四_五_六'.split('_'), weekdaysMin : function (m) { return this._weekdaysMin[m.day()]; },
修改年月显示效果:
修改Kalendae.prototype的titleFormattitleFormat:'MMMM, YYYY年',
最终效果:
指定的div使用Kalendae
前面都是通过指定class来使用kalendae,可以通过JavaScript代码指定容器使用kalendae。<div id="datepk"></div> <script type="text/javascript"> /*使用方式: new Kalendae(指定容器,配置); 配置属性注解: months属性表示日历显示几个月,值:1、2、3.....;默认值:1 mode属性表示显示的是单选还是多选还是范围,值:'single'、'multiple'、'range';默认值:'single' subscribe属性表示绑定kalendea指定的事件,支持的事件有change、date-clicked、view-changed */ new Kalendae(document.getElementById("datepk"), { months:1, mode:'multiple', subscribe: { 'date-clicked': function (date) { console.log(date._i, this.getSelected()); } } }); </script>
完整代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <link rel="stylesheet" href="./build/kalendae.css" type="text/css"> <script type='text/javascript' src='./build/kalendae.standalone.js'></script> <title>KalendaeDemo</title> </head> <body> <p>3指定div使用(多选):</p> <div id="datepk" style="width: 100%;"></div> </body> <script type="text/javascript"> new Kalendae(document.getElementById("datepk"), { months:1, mode:'multiple', subscribe: { 'date-clicked': function (date) { console.log(date._i, this.getSelected()); } } }); </script> </html>
修改控件显示的大小
(问题:当页面很小的时候布局会乱……) 修改kalendae.css
设置.kalendae .k-calendar的width为100%;
.kalendae .k-calendar { display: inline-block; zoom:1; *display:inline; /* width改为100% width:155px;*/ width: 100%; vertical-align:top; }
设置.kalendae .k-title,
.kalendae .k-header,
.kalendae .k-days 的width为100%;
.kalendae .k-title, .kalendae .k-header, .kalendae .k-days { /* width改为100% */ /* width:154px; */ width: 100%; display:block; overflow:hidden; }
.kalendae .k-header span 的width为12.8%;
.kalendae .k-header span { text-align:center; font-weight:bold; /* 这里的width要和.kalendae .k-days span 里面的相等 */ width:12.8%; padding:1px 0; color:#666; }
.kalendae .k-days span 的width为12.8%;
.kalendae .k-days span { /* 水平居中 */ text-align:center; width:12.8%; /* 高度 4.5em效果比较好 height等于line-height就能垂直居中了 */ height:4.5em; line-height:4.5em; padding:2px 3px 2px 2px; border:1px solid transparent; border-radius:3px; color:#999; }
.kalendae .k-header span 和.kalendae .k-days span的width要相等
设置文字显示的样式:
.kalendae .k-days span { /* 水平居中 */ text-align:center; width:12.8%; /* 高度 4.5em效果比较好 height等于line-height就能垂直居中了 */ height:4.5em; line-height:4.5em; padding:2px 3px 2px 2px; border:1px solid transparent; border-radius:3px; color:#999; }
最终效果:
个性化配置的css和js demo代码下载
相关文章推荐
- 日期多选插件Kalendae.js 动态引用
- [置顶] 日期多选插件Kalendae.js
- js 日历控件日期多选 kalendae.js
- 日期时间插件flatpickr.js使用方法
- 纯原生js移动端日期选择插件
- My97DatePicker日期插件WdatePicker.js的使用方法
- jquery.datetimepicker.js时间插件去除默认值的属性(点击以后不选择日期)
- js日期插件
- js日期插件dateHelp获取本月、三个月、今年的日期
- 简单易用的JS日期插件
- 基于vuejs+webpack的日期选择插件
- JS日期插件
- js日期插件
- 前端日期选取插件bootstrap-datepicker.js的使用
- jQuery日期和时间插件(jquery-ui-timepicker-addon.js)jquerydatapicker插件 实现时分秒
- JS多选日期
- 时间插件,js格式化,js某月天数,js某月最后一天日期
- js日期插件
- (很好用)JS时间控件实现日期的多选
- 一款日期插件,不要忘了最后的APP.init js插件去找含有date的