According to the document 您需要使用markedDates={} 来显示突出显示的日期。
<Calendar
markedDates={{
'2012-05-16': {selected: true, marked: true, selectedColor: 'blue'},
'2012-05-17': {marked: true},
'2012-05-18': {marked: true, dotColor: 'red', activeOpacity: 0},
'2012-05-19': {disabled: true, disableTouchEvent: true}
}}
/>
编辑
- 将
markedDates 添加到初始状态。
state = {
selectedDate: "",
markedDates: {}
};
- 更改
getSelectedDayEvents 函数以创建 markedDates 对象并将其分配给状态。
getSelectedDayEvents = date => {
let markedDates = {};
markedDates[date] = { selected: true, color: '#00B0BF', textColor: '#FFFFFF' };
let serviceDate = moment(date);
serviceDate = serviceDate.format("DD.MM.YYYY");
this.setState({
selectedDate: serviceDate,
markedDates: markedDates
});
};
- 更改日历组件以接受
markedDates
<Calendar
style={{ height: 300, width: "90%", justifyContent: "center" }}
theme={{
backgroundColor: "#ffffff",
calendarBackground: "#ffffff",
todayTextColor: "#57B9BB",
dayTextColor: "#222222",
textDisabledColor: "#d9e1e8",
monthTextColor: "#57B9BB",
arrowColor: "#57B9BB",
textDayFontWeight: "300",
textMonthFontWeight: "bold",
textDayHeaderFontWeight: "500",
textDayFontSize: 16,
textMonthFontSize: 18,
selectedDayBackgroundColor: "#57B9BB",
selectedDayTextColor: "white",
textDayHeaderFontSize: 8
}}
minDate={"1996-05-10"}
maxDate={"2030-05-30"}
monthFormat={"MMMM yyyy "}
markedDates={this.state.markedDates}
scrollEnabled={true}
horizontal={true}
showScrollIndicator={true}
disableMonthChange={true}
onDayPress={day => {
getSelectedDayEvents(day.dateString);
}}
/>
如果您有任何面团,请随时询问。希望这会对你有所帮助。