jQuery glDatePicker插件无法在IE上正确呈现

时间:2015-03-20 16:25:55

标签: jquery html internet-explorer

我正在使用glDatePicker plugin

页面加载,日历被隐藏(沿着它上面的框右边)。单击switch-view,重新呈现日历并显示日历。 Chrome, FF, Safari,一切都好。 IE,而不是那么多。看起来,当呈现日历时,width未按预期应用。

element.style {
  z-index: 1000;
  width: 382px;
  top: 259px;
  left: 766.5px;
  display: block;

IE

enter image description here

如果我将382px上的宽度更改为IE,则会显示它应该显示的内容。

<article id="events" class="clearfix hidden-xs">
    <header class="clearfix header-title">
        <h2 class="row col-sm-8">Upcoming Events</h2>
        <a href="/resource-center/calendar-of-events" class="arrow-link gray-medium col-sm-4">All Events <span class="glyphicon glyphicon-arrow-right"></span></a>
    </header>
    <div class="row">
        <section class="col-md-6 col-sm-6">
            <div id="calendar"></div>
        </section>
        <aside id="event-description" class="col-md-6  col-sm-6 gray-light">
            <img src="/content/images/events-backsplash.jpg" class="img-responsive" />
            <div id="event-data">
                ....HTML here - not relevant
            </div>
        </aside>
    </div>
</article>

$('#switch-view').click(function (e) {
    var $this = $(this);
    if ($this.hasClass('list-view')) {
        $('#event-description').hide();

        var $cal = $('#calendar').glDatePicker(true);
        $.extend($cal.options, {
            showAlways: false
        });

        $cal.render();
        $cal.hide();

        $('#calendar-list').fadeIn();
        $this.removeClass('list-view').find('span').text('Calendar View');
    }
    else {
        $this.addClass('list-view').find('span').text('List View');
        $('#calendar-list').hide();
        $('#event-description').fadeIn(function () {
            var $cal = $('#calendar').glDatePicker(true);
            $.extend($cal.options, {
                showAlways: true
            });

            $cal.render();
            $cal.show();
        });
    }

    e.preventDefault();
});

我发现我必须extend选项并更改showAlways属性以正确隐藏/显示在IE上。如果我删除了那些,那么在调用$cal.hide()函数时,日历永远不会隐藏。

你会认为我只能hide #calendar或它的容器,但这个插件的运作方式是它在创建之前创建了一个全新的<div>结束<body>标记并执行其#34;位置魔术&#34;。

Chrome

enter image description here

1 个答案:

答案 0 :(得分:0)

可能不是关于为什么会这样做的问题的答案,但不知何故IE 11只是没有在outerWidth()上正确地收集offSet()page load方法

我最终做的是确定浏览器是否实际上是IE 11,然后在初始设置日历之前设置timeout 1000ms

如果有人有更好的答案,我很乐意听到。

Apprec!