dhtmlxScheduler 支持以下触控设备:
调度器同样可以在智能手机上运行,但由于屏幕空间有限,可能需要进行一些手动设置。
实用提示!
<meta name="viewport" content="width=device-width, initial-scale=1">
当你通过 header 配置属性初始化 Scheduler 时,可以选择适合客户端屏幕尺寸的 header 布局。 这同样会应用相应的样式,自动调整小屏幕下的元素和字体大小。
例如,你可以将 header 分为多行:
上图展示的是在小屏幕下的 Scheduler。
此设置可以动态切换,因此你可以为大屏和小屏分别定义不同的 header 配置:
// 定义配置
const compactHeader = {
rows: [
{
cols: [
"prev",
"date",
"next",
]
},
{
cols: [
"day",
"week",
"month",
"spacer",
"today"
]
}
]
};
const fullHeader = [
"day",
"week",
"month",
"date",
"prev",
"today",
"next"
];
// 添加切换逻辑,根据当前屏幕尺寸选择合适的配置
function resetConfig(){
let header;
if (window.innerWidth < 1000) {
header = compactHeader;
} else {
header = fullHeader;
}
scheduler.config.header = header;
return true;
}
// 初始应用配置,并在调度器重绘或调整大小时重新应用:
resetConfig();
scheduler.attachEvent("onBeforeViewChange", resetConfig);
scheduler.attachEvent("onSchedulerResize", resetConfig);
scheduler.config.responsive_lightbox = true; // 响应式 lightbox
scheduler.init("scheduler_here");
Related sample: Responsive scheduler
Scheduler API 提供了 responsive_lightbox 选项,使 lightbox 能适应不同屏幕尺寸。
scheduler.config.responsive_lightbox = true; // 默认关闭
// 设置为 true 以启用 lightbox 响应式
如下图所示,lightbox 会在小屏幕下自动调整:
Related sample: Responsive scheduler
你可以自定义响应式 lightbox 的外观。当启用响应式时,lightbox 会额外获得一个 CSS 类 dhx_cal_light_responsive,你可以在样式中针对该类进行定制。
默认情况下,该类包含的媒体查询仅在屏幕宽度小于 1024px 时生效,允许你针对这些设备调整 lightbox 的外观。
以下是与移动端及自适应支持相关的配置选项:
为提升触控体验,库内置了 "Quick Info" 扩展。
该扩展会用更大、更友好的控件替换标准侧边栏按钮和小型编辑表单(在触控设备上不易点击)。
要启用大按钮调度器,只需在页面中引入 "Quick Info" 扩展:
<script>
scheduler.plugins({
quick_info: true
});
scheduler.init('scheduler_here',new Date(2019,5,30),"day");
...
<script>
Related sample: Touch-oriented scheduler
启用后,调度器会用更大的按钮替换标准按钮:
请注意,quick-info 选择侧边菜单与标准调度器中的选择菜单共用同一配置,详见 icons_select。
该扩展提供: