日期单选、多选、范围选插件---Kalendae.js

转载自:日期多选插件Kalendae.js(侵权删)

插件下载地址:Github下载

下载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 -->

Kalendae.js一句话介绍

Kalendae.js是一款强大的日期多控件(插件),支持日期的单选、日期的多选、日期的范围选择

在页面使用:新建一个demo.html

  1. 直接使用
    <!-- 单选 -->
    <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>
    
  2. 输入框使用
    <!-- 单选 -->
    <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>
    
  3. 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 : '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 : 'Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday'.split('_'),*/
_weekdays : '星期日_星期一_星期二_星期三_星期四_星期五_星期六'.split('_'),
weekdays : function (m) {
   return this._weekdays[m.day()];
},

/*_weekdaysShort : 'Sun_Mon_Tue_Wed_Thu_Fri_Sat'.split('_'),*/
_weekdaysShort : '周日_周一_周二_周三_周四_周五_周六'.split('_'),
weekdaysShort : function (m) {
   return this._weekdaysShort[m.day()];
},

/* _weekdaysMin : 'Su_Mo_Tu_We_Th_Fr_Sa'.split('_'),*/
_weekdaysMin : '日_一_二_三_四_五_六'.split('_'),
weekdaysMin : function (m) {
   return this._weekdaysMin[m.day()];
},

修改年月显示效果:(这里我没找到)

修改Kalendae.prototype的titleFormat
titleFormat:'MMMM, YYYY年',


指定的div使用Kalendae

前面都是通过指定class来使用kalendae,可以通过js代码指定容器使用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-calendarwidth为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-dayswidth为100%;

.kalendae .k-title,
.kalendae .k-header,
.kalendae .k-days {
	/* width改为100% */
	/* width:154px; */
	width: 100%;
	display:block;
	overflow:hidden;
}

.kalendae .k-header spanwidth为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 spanwidth为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 spanwidth要相等

最终效果:

单选div:
在这里插入图片描述

多选div:
在这里插入图片描述

个性化配置好的css和js的代码下载

链接:gitee下载

我的使用

<div id="paiban"></div>

<script type="text/javascript">
	new Kalendae(document.getElementById("paiban") ,{
		//attachTo:document.body, //将控件加到什么属性上,可以是DOM也可以是string
		months:1, //同时展示几个月可被选
		mode:'multiple', // single单选, multiple多选, range范围选
		dayHeaderClickable: true, //这个月的星期头是否可用被点击
		dayOutOfMonthClickable:false, //这个月之外的是否可以被选中
		//selected: selected, //被选中的哪些,后面selected需要自己写
		//subscribe属性表示绑定kalendea指定的事件,支持的事件有change、date-clicked、view-changed
		subscribe: {
	       'date-clicked': function (date) {
	           console.log(date._i, this.getSelected());
	       }
	   }
	})
</script>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章