zx-calendar, ZxReactCalendar, ZxSolidCalendar, zx-vue-calendar (Vue2.x and Vue3.x)
https://capricorncd.github.io/calendar/dist/index.html
// Import CSS files in the entry file or root component
import 'zx-calendar/css'
import { ZxCalendar } from 'zx-calendar'
import { ZxVueCalendar } from 'zx-calendar/vue'
// vue 2.x
import { ZxVueCalendar } from 'zx-calendar/vue2'
ZxVueCalendar
Docs | Demo vue2.x | Demo vue3.x
import { ZxReactCalendar } from 'zx-calendar/react'
import { ZxSolidCalendar } from 'zx-calendar/solid'
# pnpm
pnpm i zx-calendar
# npm
npm i zx-calendar
# yarn
yarn add zx-calendar
# setup
pnpm i
# start default demo
pnpm run dev
# start vue2.x.x demo
pnpm run vue2
# start vue3.x.x demo
pnpm run vue
# start react demo
pnpm run react
# start solid.js demo
pnpm run solid
// Import CSS files in the entry file or root component
import 'zx-calendar/css'
import { ZxCalendar } from 'zx-calendar'
const options = {}
// create an instance
const zxCalendar = new ZxCalendar(options)
// on change
zxCalendar.on('change', data => {
console.log(data)
})
// cancel button on click
zxCalendar.on('cancel', () => {
// ...
})
// on error
zxCalendar.on('error', err => {
console.error(err)
})
// default options
const options = {
// element selector or element, calendar will be append this `el`
el: '#app',
// calendar's types, options date/month/year
type: 'date',
// zh/jp/en that week and button text languages
lang: 'zh',
// Whether to display the full name of the week, `Mon` -> `Monday`/ 星期一(省略形式: 一)
isFullWeek: false,
// header title display format
// type is date: yyyy/MM
// type is month: yyyy
// type is year: yyyy-yyyy
titleFormatter: 'yyyy/MM',
// item suffix, 日/月/年
itemSuffix: null,
// default selected date
// yyyy-MM-dd, yyyy/MM/dd, yyyy, timestamp, Array
defaultDate: null,
// selectable date range array
// [startDate, endDate]
dateRange: [],
// show holiday info
showHoliday: false,
// function, custom item handler
// return object {text: string, value: number, fullText: string, disabled: boolean, ...}
itemFormatter: null,
// Selection mode, options single/multiple/range
mode: 'single',
// language package, used when formatting dates
langPackage: {
confirmButton: 'ok',
cancelButton: 'cancel',
clearButton: 'clear',
weeks: ["日", "一", "二", "三", "四", "五", "六"]
},
// footer buttons
// show clear, cancle and confirm button when mode=multiple/range
footerButtons: ['clear', 'cancel', 'confirm'],
// only show confirm button
// footerButtons: ['confirm'],
// change button display order
// footerButtons: ['confirm', 'clear', 'cancel'],
// ...
// justify-content
footerButtonAlign: 'flex-end',
// hide buttons of footer when mode is multiple/range
hideFooter: false,
// colors
colors: {
primary: '#f30',
// next/prev arrow color
arrow: '#999',
// holiday dot color
holidayDot: 'rgba(0, 0, 0, 0.2)',
// today/this month(year) item background color
currentItemBg: '#eee',
// white color
white: '#fff',
// selected range items background color
rangeBg: '#eee',
},
}
Set selected date
parameter | type | required | remark |
---|---|---|---|
date | string/timestamp/Date or Array[string/timestamp/Date] , null |
no | - |
// mode: single
// set select date
zxCalendar.setDate('2020/08/10')
zxCalendar.setDate('2020/08/10 22:14:59')
// clear selected date
zxCalendar.setDate()
// mode: multiple
zxCalendar.setDate(['2020/08/01', '2020/08/05', '2020/08/10'])
// mode: range
zxCalendar.setDate(['2008/01/14', '2019/12/10'])
Set current date
parameter | type | required | remark |
---|---|---|---|
date | string/timestamp/Date |
yes | - |
Set optional date range
parameter | type | required | remark |
---|---|---|---|
startDate | string/timestamp/Date |
yes | - |
endDate | string/timestamp/Date |
yes | - |
options.type | isYear | remark |
---|---|---|
date | effective | isYear=true , go to prev yearisYear= false , go to prev month |
month | invalid | go to prev year |
year | invalid | go to prev years page |
options.type | isYear | remark |
---|---|---|
date | effective | isYear=true , go to next yearisYear= false , go to next month |
month | invalid | go to next year |
year | invalid | go to next years page |
String, timestamp to Date
parameter | type | required | remark |
---|---|---|---|
date | string/timestamp/Date |
yes | - |
return Date/null
const date = zxCalendar.toDate('2020/08/10')
if (date !== null) {
console.log(date.getFullYear())
}
parameter | type | required | remark |
---|---|---|---|
date | string/timestamp/Date |
yes | |
formatter | string |
yes | yMdhmsaAwW |
langPackage | object |
no | {weeks: ['日', '月', '火', '水', '木', '金', '土']} |
formatter
2020/08/18 22:59:02
format | meaning | example |
---|---|---|
yyyy | year | 2020 |
M | month | 8 |
MM | month | 08 |
d | day | 18 |
dd | day | 18 |
h | hour | 22 |
hh | hour | 22 |
m | minute | 59 |
mm | minute | 59 |
s | second | 2 |
ss | second | 02 |
a | am/pm | pm |
A | AM/PM | PM |
w | week | 2 |
ww | week | 02 |
W | week | options: {isFullWeek: false, lang: 'zh'} , 二options: {isFullWeek: true, lang: 'zh'} , 星期二ZxCalendar.prototype.formatDate(date, 'W') , 2ZxCalendar.prototype.formatDate(date, 'WW') , 02 |
zxCalendar.formatDate(new Date(), 'yyyy/MM/dd hh:mm:ss')
// 2020/08/10 23:49:12
parameter | type | required | remark |
---|---|---|---|
eventName | string |
yes | custom event name |
fn | function |
yes | - |
zxCalendar.on('error', err => {
console.error(err)
})
zxCalendar.on('change', arr => {
console.log(arr)
})
zxCalendar.on('onWeekClick', ({el, className, innerText) => {
console.log(innerText)
})
zxCalendar.on('onTitleClick', ({el, className, innerText) => {
console.log(innerText)
})
eventName | parameter |
---|---|
change | arr |
arr
[
{
text: String,
fullText: String,
value: Number,
date: Date
}
]
zxCalendar.emit('customEvent', {})
zxCalendar.off('customEvent')
get selected dates
return Array
remove calendar from el(parent)
zxCalendar.destroy()
MIT License © 2020-Present Capricorncd.