miCalendar

setSpecialDates close hide prevMonth

miCalendar 是一个高仿小米的日历控件;支持快速滑动,并且可以显示农历,节假日,24节气的日历,可自定义日历的样式,添加特殊日期标注,切换月份,设置指定日期;用于实现常用的日期选择,日历展示功能。使用起来非常简单,就像使用ListView一样。注意:iOS 设备使用时需勾选日历权限,否则会闪退

注:针对单日的样式优先级序列为: selected>setSpecialDate>specialDate>styles_specialDate>today 模块截图:

模块接口

open

打开日历

open({params}, callback(ret))

params

rect:

  • 类型:JSON 对象
  • 描述:(可选项)模块的位置及尺寸
  • 内部字段:

currentDateTitle:

  • 类型:JSON 对象
  • 描述: (可选项)当前日期的位置和尺寸
  • 内部字段:
  1. h: 44 , //(可选项)数字类型;当前日期的高度;默认:44
  2. size:24, //(可选项) 数字类型;当前日期的文字大小;默认:24
  3. color:'#C0FF3E', //(可选项) 字符串类型;当前日期的文字的颜色;默认:'#C0FF3E'
  4. backgroundColor:'#BA55D3'//(可选项) 字符串类型;当前日期的背景颜色;默认:'#BA55D3'
  5. }

styles:

  • 类型:JSON 对象
  • 描述:(可选项)模块各部分的样式
  • 内部字段:
  1. {
  2. bg: 'rgba(0,0,0,0)', //(可选项)字符串类型;日历整体背景,支持 rgb、rgba、#、图片路径,要求本地路径(fs://、widget://);默认:'rgba(0,0,0,0)'(iOS仅支持颜色设置)
  3. viewbg: 'rgba(0,0,0,0)', //(可选项)字符串类型;整个view背景,支持 rgb、rgba、#;默认:'rgba(0,0,0,0)'(仅ios支持)
  4. cornerRadius:1, //(可选性)数字类型;设备当前日期和选中日期背景圆角;默认:1
  5. title: { //(可选项)JSON对象,星期的样式
  6. color: '#3b3b3b', //(可选项)字符串类型;文字的颜色,支持 rgb、rgba、#;默认:'#3b3b3b'
  7. size: 12 //(可选项)数字类型;星期文字的大小;默认:12
  8. },
  9. date: { //(可选项)JSON对象,普通日期的样式
  10. color: '#3b3b3b', //(可选项)字符串类型;普通日期文字的颜色;支持 rgb、rgba、#;默认:'#3b3b3b'
  11. selectedColor: '#fff', //(可选项)字符串类型;普通日期选中后的文字颜色,支持 rgb、rgba、#;默认:'#fff'
  12. selectedBg: '#a8d500', //(可选项)字符串类型;普通日期选中后的背景,支持 rgb、rgba、#,默认:'#a8d500'
  13. size: 12 //(可选项)数字类型;普通日期文字的大小;默认:12
  14. },
  15. today: { //(可选项)JSON对象,设备当前日期的样式
  16. color: '#a8d500', //(可选项)字符串类型;当前日期的文字颜色,支持 rgb、rgba、#;默认:'#a8d500'
  17. bg: '#f00' //(可选项)字符串类型;当前日期的背景,支持 rgb、rgba、#,默认'#f00'
  18. },
  19. }

specialDate:

  • 类型:数组
  • 内部字段:
  1. [{
  2. date: '2015-05-01' //字符串类型;日期字符串,格式为:yyyy-MM-dd
  3. badge: 'widget://' //(可选项)字符串类型;表示休息或者上班,图片路径,要求本地路径(fs://、widget://);默认:
  4. }]

isLunarCalendar:

  • 类型:布尔
  • 描述:(可选项)是否显示农历
  • 默认值:true

scrollEnabled:

  • 类型:布尔
  • 描述:(可选项)是否允许左右滑动切换
  • 默认值:true

isToday:

  • 类型:布尔
  • 描述:(可选项)日期选中后,设备当前日期样式是否消失,设置为true后,日期选中后,设备当前日期样式消失,选中设备当前日期后,样式显示为选中日期样式
  • 默认值:false

fixedOn:

  • 类型:字符串类型
  • 描述:(可选项)模块视图添加到指定 frame 的名字(只指 frame,传 window 无效)
  • 默认:模块依附于当前 window

fixed:

  • 类型:布尔
  • 描述:(可选项)模块是否随所属 window 或 frame 滚动
  • 默认值:true(不随之滚动)

callback(ret)

ret:

  • 类型:JSON 对象
  • 内部字段:
  1. {
  2. eventType: 'show', //字符串类型;交互事件类型
  3. //取值范围:
  4. //show(日历显示)
  5. //click(点击日期)
  6. date:'2015-05-01' //字符串类型;当前选择的日期
  7. chinaDate:' 农历己亥(猪)年三月初七' //字符串类型:农历年月日
  8. }

示例代码

  1. var miCalendar = api.require('miCalendar');
  2. miCalendar.open({
  3. rect: {
  4. x: 30,
  5. y: api.frameHeight / 2 - 170,
  6. w: api.frameWidth,
  7. h: 340
  8. },
  9. h: 44 ,
  10. size:24,
  11. color:'#C0FF3E',
  12. backgroundColor:'#BA55D3'
  13. },
  14. styles: {
  15. bg: 'rgba(0,0,0,0)',
  16. title: {
  17. color: '#3b3b3b',
  18. size: 12
  19. },
  20. date: {
  21. color: '#3b3b3b',
  22. selectedColor: '#fff',
  23. selectedBg: '#a8d500',
  24. size: 12
  25. },
  26. today: {
  27. color: 'rgb(230,46,37)',
  28. bg: '#f00'
  29. },
  30. },
  31. specialDate: [{
  32. date: '2015-06-01'
  33. }],
  34. isLunarCalendar:true,
  35. fixedOn: api.frameName,
  36. fixed: false
  37. }, function(ret, err) {
  38. if (ret) {
  39. alert(JSON.stringify(ret));
  40. } else {
  41. alert(JSON.stringify(err));
  42. });

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

setSpecialDates

setSpecialDates({params})

params

specialDates:

  • 类型:数组
  • 描述:需要标记的特殊假期数组,格式为:yyyy-MM-dd
  • 内部字段:

示例代码

  1. var miCalendar = api.require('miCalendar');
  2. miCalendar.setSpecialDates({
  3. specialDates: [{
  4. date: '2015-12-07',
  5. badge:''
  6. }, {
  7. date: '2015-12-08',
  8. badge:''
  9. }]

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

cancelSpecialDates

取消已设置的特殊假期状态

cancelSpecialDates({params})

params

specialDates:

  • 类型:数组
  • 描述:需要取消的特殊假期组成的数组,格式为:yyyy-MM-dd
  1. var miCalendar = api.require('miCalendar');
  2. miCalendar.cancelSpecialDates({
  3. specialDates: ['2015-12-08', '2015-12-07']
  4. });

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

close

关闭日历

close()

示例代码

  1. var miCalendar = api.require('miCalendar');
  2. miCalendar.close();

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

show

显示日历

show()

示例代码

  1. var miCalendar = api.require('miCalendar');
  2. miCalendar.show();

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

hide

隐藏日历

示例代码

  1. var miCalendar = api.require('miCalendar');
  2. miCalendar.hide();

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

nextMonth

显示下个月

nextMonth(callback(ret))

callback(ret)

ret:

  • 类型:JSON 对象
  • 内部字段:
  1. var miCalendar = api.require('miCalendar');
  2. miCalendar.nextMonth(function(ret, err) {
  3. if (ret) {
  4. alert(JSON.stringify(ret));
  5. } else {
  6. alert(JSON.stringify(err));
  7. }
  8. });

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

prevMonth

显示上个月

prevMonth(callback(ret))

callback(ret)

ret:

  • 类型:JSON 对象
  • 内部字段:
  1. {
  2. year: '2015', //字符串类型;当前显示的年份
  3. month: '6' //字符串类型;当前显示的月份
  4. }

示例代码

  1. var miCalendar = api.require('miCalendar');
  2. miCalendar.prevMonth(function(ret, err) {
  3. if (ret) {
  4. alert(JSON.stringify(ret));
  5. } else {
  6. alert(JSON.stringify(err));
  7. }
  8. });

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

setDate

设置选中日期(可通过此接口实现翻页效果)

setDate({params}, callback(ret))

params

date:

  • 类型:字符串
  • 描述:(可选项)选中日期,格式为:yyyy-MM-dd
  • 默认值:当前日期

ignoreSelected:

  • 类型:布尔
  • 描述:(可选项)选中日期是否忽略选中日期样式(open -> styles -> date -> selectedColor、selectedBg)
  • 默认值:false

callback(ret)

ret:

  • 类型:JSON 对象
  • 内部字段:
  1. {
  2. status: true //布尔型;true||false
  3. }

示例代码

  1. var miCalendar = api.require('miCalendar');
  2. miCalendar.setDate({
  3. date: '2015-08-08',
  4. ignoreSelected: false
  5. }, function(ret, err) {
  6. if (ret.status) {
  7. alert(JSON.stringify(ret));
  8. } else {
  9. alert(JSON.stringify(err));
  10. }
  11. });

可用性

iOS系统,Android系统