bootstrap jquery popover size

时间:2013-11-21 09:47:21

标签: jquery fullcalendar twitter-bootstrap-3

在我的带有bootstrap和fullcalender的应用程序中,弹出窗口的大小无法正确显示。有可能调整大小??我正在使用bootstrap 3。 enter image description here

代码

$(window).load(function() { 
        var date = new Date();
        var d = date.getDate();
        var m = date.getMonth();
        var y = date.getFullYear();

        /* initialize the external events
        -----------------------------------------------------------------*/

        $('#external-events div.external-event').each(function() {

            // create an Event Object (http://arshaw.com/fullcalendar/docs/event_data/Event_Object/)
            // it doesn't need to have a start or end
            var eventObject = {
                title: $.trim($(this).text()) // use the element's text as the event title
            };

            // store the Event Object in the DOM element so we can get to it later
            $(this).data('eventObject', eventObject);

            // make the event draggable using jQuery UI
            $(this).draggable({
                zIndex: 999,
                revert: true,      // will cause the event to go back to its
                revertDuration: 0  //  original position after the drag
            });

        });



        /* initialize the calendar
        -----------------------------------------------------------------*/

        $('#calendar').fullCalendar({
            header: {
                left: 'prev,next today',
                center: 'title',
                right: 'month,agendaWeek,agendaDay'
            },
            editable: true,
            droppable: true, // this allows things to be dropped onto the calendar !!!
            eventRender: function (event, element) {
                element.popover({
                    title: "My Title",
                    placement:'auto',
                    html:true,
                    trigger : 'click',
                    animation : 'true',
                    content: event.msg
                });
                $('body').on('click', function (e) {
                    if (!element.is(e.target) && element.has(e.target).length === 0 && $('.popover').has(e.target).length === 0)
                        element.popover('hide');
                });
              },

            events: [
                        {
                            title: 'All Day Event',
                            start: new Date(y, m, 1),
                            msg: 'I am OK',  
                        },
                        {
                            title: 'Long Event',
                            start: new Date(y, m, d-5),
                            end: new Date(y, m, d-2),
                            msg: 'I am double OK',  
                        },
                        {
                            id: 999,
                            title: 'Repeating Event',
                            start: new Date(y, m, d-3, 16, 0),
                            allDay: false
                        },
                        {
                            id: 999,
                            title: 'Repeating Event',
                            start: new Date(y, m, d+4, 16, 0),
                            allDay: false
                        },
                        {
                            title: 'Meeting',
                            start: new Date(y, m, d, 10, 30),
                            allDay: false
                        },
                        {
                            title: 'Lunch',
                            start: new Date(y, m, d, 12, 0),
                            end: new Date(y, m, d, 14, 0),
                            allDay: false
                        },
                        {
                            title: 'Birthday Party',
                            start: new Date(y, m, d+1, 19, 0),
                            end: new Date(y, m, d+1, 22, 30),
                            allDay: false
                        },
                        {
                            title: 'Click for Google',
                            start: new Date(y, m, 28),
                            end: new Date(y, m, 29),
                            url: 'http://google.com/'
                        }
                    ]       
        }); 

    });

的jsfiddle http://jsfiddle.net/7gwz5/

2 个答案:

答案 0 :(得分:4)

为此获得解决方案

刚刚将{container:'body'}添加到事件弹出中,效果很好

element.popover({
                title: "My Title",
                placement:'auto',
                html:true,
                trigger : 'click',
                animation : 'true',
                content: event.msg,
                container:'body'
            });

更新了jslint http://jsfiddle.net/7gwz5/2/

答案 1 :(得分:0)

我不知道fullcalendar,但是经典的Bootstrap popover结构看起来像这样:

<div class="popover">
    <h3 class="popover-title">Title</h3>
    <div class="popover-content">Content</div>
</div>

然后你只需要将大小设置为.popover类,它应该可以工作;还要验证您的javascript插件不会改变大小或更改类(例如,使用Google Chrome的开发人员工具)。 如果它仍然不起作用,请发布您的代码,我们可以轻松调试它。 ;)