首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >pickadate使用变量设置禁用天数

pickadate使用变量设置禁用天数
EN

Stack Overflow用户
提问于 2020-06-29 22:13:25
回答 2查看 150关注 0票数 1

我希望根据从select-input中选择的内容来动态设置禁用天数。我的选项有以下数据字段:

代码语言:javascript
复制
data-disableddays="2,3,4,5"

我的select上有一个onchange事件。在这里,我得到了数据禁用天数的值:

代码语言:javascript
复制
var disableddays = $(this).find(':selected').data('disableddays');

console.log输出正确(2,3,4,5)

当我初始化pickadate时:

代码语言:javascript
复制
var picker = $('#tripstart').pickadate({
                        format: 'd.mm.yyyy',
                        min: new Date($mystart),
                        max: new Date($myend),
                        firstDay: 1,
                        disable: [
                          disableddays
                        ]
                      });

什么都没发生。将变量disabledday替换为"2,3,4,5“一切运行正常。我要怎么做才能让这个变量在这个地方工作呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-06-29 22:21:33

试着这样做

代码语言:javascript
复制
var disableddays = $(this).find(':selected').data('disableddays');
disableddays = disableddays.split(',').map(day=>parseInt(day));
var picker = $('#tripstart').pickadate({
                        format: 'd.mm.yyyy',
                        min: new Date($mystart),
                        max: new Date($myend),
                        firstDay: 1,
                        disable: disableddays
                      });

基本上,disabledays应该是一个整数数组。

票数 4
EN

Stack Overflow用户

发布于 2020-06-29 22:25:51

因为您使用的是字符串"2,3,4,5“而不是数组,所以您需要使用disableddays.split(",")将字符串转换为数组,如下所示:

代码语言:javascript
复制
var picker = $('#tripstart').pickadate({
                 format: 'd.mm.yyyy',
                 min: new Date($mystart),
                 max: new Date($myend),
                 firstDay: 1,
                 disable: disableddays.split(",")
             });
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62640053

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档