我使用的是以下代码:
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");
}
(未测试)