Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ljcheibao/vue-component-monthcalender
typescript+vue开发的月份单位的日历组件,使用swiper库来支持日历滑动功能,简单易用
https://github.com/ljcheibao/vue-component-monthcalender
calender component frontend javascript typescript vue
Last synced: 2 months ago
JSON representation
typescript+vue开发的月份单位的日历组件,使用swiper库来支持日历滑动功能,简单易用
- Host: GitHub
- URL: https://github.com/ljcheibao/vue-component-monthcalender
- Owner: ljcheibao
- License: mit
- Created: 2018-08-27T15:11:13.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-08-30T10:27:34.000Z (over 6 years ago)
- Last Synced: 2024-10-13T03:38:46.590Z (3 months ago)
- Topics: calender, component, frontend, javascript, typescript, vue
- Language: Vue
- Homepage:
- Size: 288 KB
- Stars: 5
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
### vue 日历(以月为单位)组件
typescript+vue开发的以月份为基础单位的日历组件,使用swiper库来支持日历滑动功能,简单易用
[![npm](https://img.shields.io/npm/l/vue-component-monthcalender.svg)](LICENSE)
[![NPM Version](https://img.shields.io/npm/v/vue-component-monthcalender.svg)](https://www.npmjs.com/package/vue-component-monthcalender)
[![npm](https://img.shields.io/npm/dt/vue-component-monthcalender.svg)](https://www.npmjs.com/package/vue-component-monthcalender)#### 代码示例
![image](https://raw.githubusercontent.com/ljcheibao/vue-component-monthcalender/master/images/one.png)
![image](https://raw.githubusercontent.com/ljcheibao/vue-component-monthcalender/master/images/two.png)- 安装组件包
```
npm install vue-component-monthcalender --save-dev
```- js代码
```js
import Vue from 'vue';
import VueMcalender from "vue-component-monthcalender";new Vue({
el: '#app',
components: {
VueMcalender
},
data() {
return {
visible:true,
options: {
showHeader: true,
beginDate: "2018-07-30",
endDate: "2018-08-12",
currentDate: "2018-08-03"
}
}
},
methods: {
chooseDayItemHandle: function (dayItem) {
console.log(dayItem)
},slideChangeHandle:function(item) {
console.log(item);
}
}
});
```- html模板
```html
```### 组件API
#### 通过v-model数据双向绑定来控制组件的显示隐藏
- calender props
| 属性 | 说明 | 类型 | 默认值 |
| ------------------------ | ------------------------------------------------------------ | ------------- | ------ |
| option | **option**对象提供4个属性值:
**showHeader**是否显示标题),
**beginDate**(开始时间:yyyy-MM-dd格式),
**endDate**(结束时间:yyyy-MM-dd格式),
**currentDate**(当前时间:yyyy-MM-dd格式) | object | 空对象 |
| reset(**预留扩展字段**) | 是否需要重置初始化生成的日历的每天日期,默认值为false,
该值设置为true以后,使用者可设置**status**属性,来自定义修改生成的日历每天日期状态,原来日历中每一项均不可点,即每一项的
**enabled**属性会被重置为false | boolean | false |
| status(**预留扩展字段**) | 需要自定义的日期状态数组(reset属性为true有效),
数组的每一项是个object对象,对象提供一下几个属性:
**currentDate**:string类型,当前日期格式yyyy-MM-dd
**dayClass**:string类型,当前日期显示的样式名称
**enabled**:boolean类型,是否可用(可以点击)
**default**:boolean类型,是否是默认选中的一天,true为默认选中的一天,
**需要注意的是,status的数组对象中,仅有一项default的值为true(有多个日期为选中状态,不符合实际需求吧)** | Array | [] |- calender events
| 方法名称 | 说明 | 参数 |
| -------- | ---------------- | ------------------------------------------------------------ |
| on-click | 日历上某一天触发 | 当前日期对象,对象有以下属性:
**currentDate**:选中的日期,格式:yyyy-MM-dd,
**dayClass**:类名称,
**dayDesc/day**:几号,如:2,
**enabled**:是否可以点击,true表示可以点击 |
| on-slide | 左右滑动日历触发 | 返回滑动到的下一个日历的第一天日期,格式:yyyy-MM-dd格式 |### 组件开发说明
- 安装依赖
```
npm/cnpm install
```- 编译
```
npm run build
```- demo运行
```
# cd test
# npm/cnpm install
# npm run build#把test目录的index.html在浏览器打开,切换到移动的端模拟器,可以预览在手机端的展示结果
```### 备注
**相互学习共同提高,欢迎使用并且issue**