使用FullCalendar

时间:2017-07-07 14:50:17

标签: javascript jquery jquery-ui fullcalendar jquery-ui-contextmenu

我正在处理Martin Wendt's jQuery Context-menu plugin,我正在尝试将其集成到我的FullCalendar插件中。问题是右键单击事件没有任何反应。所以,没有上下文菜单弹出。

我在default.html文件中显示以下jquery代码,显示日历:

        $('#calendar').fullCalendar({
            eventRender: function(event, element) {
                var originalClass = element[0].className;
                element[0].className = originalClass + ' hasmenu';
            },
            //
        });

        $('#calendar').contextmenu({
            delegate: '.hasmenu',
            menu: [
                {title: 'Copy', cmd: 'copy', uiIcon: 'ui-icon-copy'},
                {title: '----'},
                {title: 'More', children: [
                    {title: 'Sub 1', cmd: 'sub1'},
                    {title: 'Sub 2', cmd: 'sub1'}
                    ]}
                ],
            select: function(event, ui) {
                alert('select ' + ui.cmd + ' on ' + ui.target.text());
            }
        });

正如您所看到的,似乎代码没有任何问题,因为我完全按照过程启用了jquery上下文菜单,在右键单击某个事件时弹出。以下是上下文菜单插件所需的依赖项:

<link href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css" 
    rel="stylesheet" />
<script src="//code.jquery.com/jquery-3.2.1.min.js"></script>
<script src="//code.jquery.com/ui/1.12.1/jquery-ui.min.js"></script>
<script src="assets/jquery.ui-contextmenu.min.js"></script>

为了实现它,在我的部分开头,我包含了FullCalendar和Contextmenu的依赖项:

<link href='//code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.css' rel='stylesheet' />
<link href='../fullcalendar.min.css' rel='stylesheet' />
<link href='../fullcalendar.print.min.css' rel='stylesheet' media='print' />
<script src='../lib/moment.min.js'></script>
<script src='../lib/jquery.min.js'></script>
<script src='../fullcalendar.min.js'></script>
<script src='//code.jquery.com/jquery-1.11.3.min.js'></script>
<script src='//code.jquery.com/ui/1.11.4/jquery-ui.min.js'></script>
<script src='../jquery.ui-contextmenu.min.js'></script>

jquery.ui-contextmenu.min.js文件突然出现在我fullcalendar.min.js所在的主文件夹中,您可以注意到。

1 个答案:

答案 0 :(得分:0)

我根据上面的代码制作了一个小提琴,其中上下文菜单确实出现但显示在日历的后面并且无法访问。

https://jsfiddle.net/xc7styt5/

enter image description here

如果更改类ui-contextmenu的z-index,它应该起作用。

https://jsfiddle.net/p52gohwn/

.ui-contextmenu {
  z-index: 1;
}

(可能有更好的方式)