自定义页面日历图
本案例来自三方开发者「李睿」
1. 使用场景
本例介绍一下在宜搭自定义页面中如何实现日历效果。
2. 实现功能
2.1. 创建自定义页面
data:image/s3,"s3://crabby-images/dbf12/dbf12437aff85dbd6353bff350937952a2e4a27c" alt=""
2.2. 数据源配置
(1)点击数据源按钮,配置变量
data:image/s3,"s3://crabby-images/aa1db/aa1dbeec7d6d4360095aaa31b3af771facf7b2db" alt=""
data:image/s3,"s3://crabby-images/2c8b0/2c8b03b371bb664457426866247b010735a015ab" alt=""
this.utils.formatter('date',Date.now(),'YYYY-M-D')
data:image/s3,"s3://crabby-images/a645d/a645d4549eb391808e7e0eedbcbc77f9d69d3f25" alt=""
new Date().getFullYear()
data:image/s3,"s3://crabby-images/e796b/e796b6ba31702d5a01c690301cdeefe85066ad94" alt=""
new Date().getMonth() + 1
2.3. 变量绑定
data:image/s3,"s3://crabby-images/19101/191011c6499967e24851dae9cc22452d1a04c0c3" alt=""
state.year !== new Date().getFullYear() || state.month !== new Date().getMonth() + 1 || state.clickValue !== this.utils.formatter('date',Date.now(),'YYYY-M-D') ? 'NORMAL' : 'DISABLED'
data:image/s3,"s3://crabby-images/a5fb7/a5fb7072af15fea82a36ecbd27cf152d6cbb9b3b" alt=""
`${state.year}年${state.month}月`
data:image/s3,"s3://crabby-images/cfbb0/cfbb00f683dbd888ba44790b06e972f16b51fa47" alt=""
data:image/s3,"s3://crabby-images/37d53/37d53f14b01caa44296f1d72e4aa6bdfa7715fdc" alt=""
`${item.type} ${item.dateString === state.clickValue? 'isChecked' : ''}`
data:image/s3,"s3://crabby-images/ed001/ed001c1ded9d111fd12189389ce7b1b852fc782f" alt=""
2.4. 事件绑定
data:image/s3,"s3://crabby-images/ca628/ca628a2a20721542ab89baa11a6f2c1cd0b481b6" alt=""
export function didMount() {
this.renderCalendar();
}
// 日历渲染
export function renderCalendar() {
const { year, month } = this.state;
// 获取当前月第一天星期数
const nowMonthStartDayWeekNum = new Date(year, month - 1, 1).getDay();
// 获取当前月最后一天星期数
const nowMonthEndDayWeekNum = new Date(year, month, 0).getDay();
// 获取当前月最后一天天数
const nowMonthEndDayNum = new Date(year, month, 0).getDate();
// 获取上个月最后一天天数
const lastMonthEndDayNum = new Date(year, month - 1, 0).getDate();
const lastMonthDateList = _.range(lastMonthEndDayNum - nowMonthStartDayWeekNum + 1, lastMonthEndDayNum + 1, 1).map((item) => {
return {
type: 'lastMonth',
isToday: false,
year: month - 1 > 0 ? year : year - 1,
month: month - 1 > 0 ? month - 1 : 12,
day: item,
dateString: `${month - 1 > 0 ? year : year - 1}-${month - 1 > 0 ? month - 1 : 12}-${item}`,
};
}); // 上月日期序列
const nowMonthDateList = _.range(1, nowMonthEndDayNum + 1, 1).map((item) => {
return {
type: 'nowMonth',
isToday: item === new Date().getDate() && month === new Date().getMonth() + 1 && year === new Date().getFullYear(),
year,
month,
day: item,
dateString: `${year}-${month}-${item}`,
};
}); // 本月日期序列
const nextMonthDateList = _.range(1, 7 - nowMonthEndDayWeekNum, 1).map((item) => {
return {
type: 'nextMonth',
isToday: false,
year: month - 1 < 13 ? year : year + 1,
month: month + 1 < 13 ? month + 1 : 1,
day: item,
dateString: `${month - 1 < 13 ? year : year + 1}-${month + 1 < 13 ? month + 1 : 1}-${item}`,
};
}); // 下月日期序列
this.setState({
calendarDateList: [...lastMonthDateList, ...nowMonthDateList, ...nextMonthDateList],
});
}
// 切换年月
export function changeYearOrMonth() {
const { type } = this.params;
const { year, month } = this.state;
switch (type) {
case 'lastYear':
this.setState({
year: year - 1,
});
break;
case 'nextYear':
this.setState({
year: +year + 1,
});
break;
case 'lastMonth':
this.setState({
month: month - 1 > 0 ? month - 1 : 12,
year: month - 1 > 0 ? year : year - 1,
});
break;
case 'nextMonth':
this.setState({
month: +month + 1 < 13 ? +month + 1 : 1,
year: +month + 1 < 13 ? year : +year + 1,
});
break;
case 'nowMonth':
this.setState({
month: new Date().getMonth() + 1,
year: new Date().getFullYear(),
clickValue: this.utils.formatter('date', Date.now(), 'YYYY-M-D'),
});
break;
default:
console.log('无效的状态');
break;
}
this.renderCalendar();
}
data:image/s3,"s3://crabby-images/967c0/967c0eb8f64e1d27b304efdac473b034e5111b6f" alt=""
// 点击日历
export function onCalendarCellClick() {
console.log(this.item);
this.setState({
clickValue: this.item.dateString,
});
}
3. 实现效果
data:image/s3,"s3://crabby-images/9595a/9595a2cfad713caf0421df60fb1ec13a76b64dee" alt=""
4. 在线试玩
本文档对您是否有帮助?