我正在使用glDatePicker plugin。
页面加载,日历被隐藏(沿着它上面的框右边)。单击switch-view
,重新呈现日历并显示日历。 Chrome, FF, Safari
,一切都好。 IE
,而不是那么多。看起来,当呈现日历时,width
未按预期应用。
铬
element.style {
z-index: 1000;
width: 382px;
top: 259px;
left: 766.5px;
display: block;
IE
如果我将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;。
答案 0 :(得分:0)
可能不是关于为什么会这样做的问题的答案,但不知何故IE 11
只是没有在outerWidth()
上正确地收集offSet()
和page load
方法
我最终做的是确定浏览器是否实际上是IE 11
,然后在初始设置日历之前设置timeout
1000ms
。
如果有人有更好的答案,我很乐意听到。
Apprec!