jQuery从1.8.3到1.9.1的迁移停止在一行中工作,我不知道为什么



我使用的是以下代码:

http://labs.abeautifulsite.net/archived/jquery-alerts/demo/

在jQuery 1.8.3下可以正常工作。

现在我切换到jQuery 1.9.1,它停止工作

我的大多数其他代码都有问题,主要是我不得不将。live更改为。on并解决了问题(我不知道这是否是正确的事情),但使用此代码,我没有发现问题。

这一行似乎给出了问题:

// IE6 Fix
var pos = ($.browser.msie && parseInt($.browser.version) <= 6 ) ? 'absolute' : 'fixed';

你可以在jsFiddle中测试它,你可以切换到jQuery 1.8.3,看看它是如何工作的。

http://jsfiddle.net/sebababi/P8sfn/1/

$.browser在jQuery 1.3中已弃用,并在1.9中删除。

http://jquery.com/upgrade-guide/1.9/jquery-browser-removed

当迁移到1.9x时,你应该使用jQuery migrate插件来查看任何错误。此外,jQuery建议在Modernizr等库中使用特性检测。

可以使用jQuery Migrate插件调用$.browser。会成功的!

使用插件很容易;只需要在jQuery的script标签之后立即包含它,例如

<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/jquery-migrate-1.1.1.js"></script>

JS:

$.each($.browser, function(i, val) {
  $("<div>" + i + " : <span>" + val + "</span>")
  .appendTo( document.body );
});

DEMO HERE(参见左侧的Migrate 1.1.0复选框被选中)

$。浏览器已从1.9删除。你可以使用jQuery Migrate来获得$。浏览器支持。

参见前文:TypeError: 'undefined'不是对象(求值'$.browser.msie')

使用特征检测

var someEl = $("#theid");
someEl.css("position","fixed");
if ( someEl.css("position") == "static" ) {
    // doesn't support fixed, use absolute
    someEl.css("position","absolute");
}

(未测试)

相关内容

  • 没有找到相关文章

最新更新