jQuery(1.6.3) 中css方法對(duì)浮動(dòng)的實(shí)現(xiàn)缺陷分析
更新時(shí)間:2011年09月09日 10:26:44 作者:
JavaScript中設(shè)置元素的浮動(dòng)屬性(float),標(biāo)準(zhǔn)瀏覽器使用cssFloat,IE舊版本使用styleFloat。
jQuery的css方法統(tǒng)一了兩種寫法,直接使用float屬性即可,如下css方法中傳參數(shù)“float”即可以設(shè)置也可以獲取元素的float。
<div id="d1">float div</div>
<script type="text/javascript">
$('#d1').css('float', 'right');
var str = $('#d1').css('float');
alert(str);
</script>
但jQuery非要自作聰明,加上對(duì)cssFloat和styleFloat的支持,見API文檔,比如獲取元素的float屬性時(shí),以下是等價(jià)的。
1 $('div.left').css('float');
2 $('div.left').css('cssFloat');
3 $('div.left').css('styleFloat');
但方式3在各個(gè)瀏覽器中返回值不同,比如使用styleFloat獲取浮動(dòng)
<div id="d1">float div</div>
<script type="text/javascript">
alert($('#d1').css('styleFloat'));
</script>
元素div沒有設(shè)置浮動(dòng),因此默認(rèn)應(yīng)該返回“none”。但結(jié)果是
IE6/7/8 : 返回空字符串"none"
IE9/Firefox/Safari/Chrome/Opera : 返回空字符串
又如使用cssFloat設(shè)置浮動(dòng):
<div id="d1">float div</div>
<script type="text/javascript">
$('#d1').css('cssFloat', 'right');
</script>
IE6/7/8:設(shè)置未成功
IE9/10/Firefox/Safari/Chrome/Opera:設(shè)置成功
又如使用styleFloat設(shè)置浮動(dòng):
<div id="d1">float div</div>
<script type="text/javascript">
$('#d1').css('styleFloat', 'right');
</script>
IE6/7/8/9/10/Opera:設(shè)置成功(Opera是個(gè)怪胎,styleFloat和cssFloat都支持)
Firefox/Safari/Chrome:設(shè)置不成功
因此,使用css方法獲取或設(shè)置浮動(dòng)時(shí)為避免各瀏覽器差異還是老老實(shí)實(shí)的使用float。不要使用styleFloat或cssFloat。
當(dāng)然如果這算jQuery的bug,那么修復(fù)也是很容易的
1,修改jQuery.css方法,加個(gè)styleFloat的判斷。
// cssFloat needs a special treatment
if ( name === "cssFloat" || name === "styleFloat") {
name = "float";
}
這樣使用$(xx).css("styleFloat") 就沒有兼容性問題了。
2,修改jQuery.style方法,加個(gè)判斷如果傳styleFloat或cssFloat都轉(zhuǎn)成float
// Don't set styles on text and comment nodes
if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) {
return;
}
// 這是加的修復(fù)代碼
if( name === "cssFloat" || name === "styleFloat" ) {
name = "float"
}
// Make sure that we're working with the right name
var ret, type, origName = jQuery.camelCase( name ),
style = elem.style, hooks = jQuery.cssHooks[ origName ];
這樣使用$(xx).css("cssFloat", "right") 或 $(xx).css("styleFloat", "right") 各瀏覽器就都o(jì)k了。
復(fù)制代碼 代碼如下:
<div id="d1">float div</div>
<script type="text/javascript">
$('#d1').css('float', 'right');
var str = $('#d1').css('float');
alert(str);
</script>
但jQuery非要自作聰明,加上對(duì)cssFloat和styleFloat的支持,見API文檔,比如獲取元素的float屬性時(shí),以下是等價(jià)的。
1 $('div.left').css('float');
2 $('div.left').css('cssFloat');
3 $('div.left').css('styleFloat');
但方式3在各個(gè)瀏覽器中返回值不同,比如使用styleFloat獲取浮動(dòng)
復(fù)制代碼 代碼如下:
<div id="d1">float div</div>
<script type="text/javascript">
alert($('#d1').css('styleFloat'));
</script>
元素div沒有設(shè)置浮動(dòng),因此默認(rèn)應(yīng)該返回“none”。但結(jié)果是
IE6/7/8 : 返回空字符串"none"
IE9/Firefox/Safari/Chrome/Opera : 返回空字符串
又如使用cssFloat設(shè)置浮動(dòng):
復(fù)制代碼 代碼如下:
<div id="d1">float div</div>
<script type="text/javascript">
$('#d1').css('cssFloat', 'right');
</script>
IE6/7/8:設(shè)置未成功
IE9/10/Firefox/Safari/Chrome/Opera:設(shè)置成功
又如使用styleFloat設(shè)置浮動(dòng):
復(fù)制代碼 代碼如下:
<div id="d1">float div</div>
<script type="text/javascript">
$('#d1').css('styleFloat', 'right');
</script>
IE6/7/8/9/10/Opera:設(shè)置成功(Opera是個(gè)怪胎,styleFloat和cssFloat都支持)
Firefox/Safari/Chrome:設(shè)置不成功
因此,使用css方法獲取或設(shè)置浮動(dòng)時(shí)為避免各瀏覽器差異還是老老實(shí)實(shí)的使用float。不要使用styleFloat或cssFloat。
當(dāng)然如果這算jQuery的bug,那么修復(fù)也是很容易的
1,修改jQuery.css方法,加個(gè)styleFloat的判斷。
復(fù)制代碼 代碼如下:
// cssFloat needs a special treatment
if ( name === "cssFloat" || name === "styleFloat") {
name = "float";
}
這樣使用$(xx).css("styleFloat") 就沒有兼容性問題了。
2,修改jQuery.style方法,加個(gè)判斷如果傳styleFloat或cssFloat都轉(zhuǎn)成float
復(fù)制代碼 代碼如下:
// Don't set styles on text and comment nodes
if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) {
return;
}
// 這是加的修復(fù)代碼
if( name === "cssFloat" || name === "styleFloat" ) {
name = "float"
}
// Make sure that we're working with the right name
var ret, type, origName = jQuery.camelCase( name ),
style = elem.style, hooks = jQuery.cssHooks[ origName ];
這樣使用$(xx).css("cssFloat", "right") 或 $(xx).css("styleFloat", "right") 各瀏覽器就都o(jì)k了。
相關(guān)文章
jQuery實(shí)現(xiàn)的表格展開伸縮效果實(shí)例
這篇文章主要介紹了jQuery實(shí)現(xiàn)的表格展開伸縮效果,結(jié)合完整實(shí)例形式分析了jQuery響應(yīng)鼠標(biāo)事件動(dòng)態(tài)修改頁(yè)面元素的相關(guān)技巧,需要的朋友可以參考下2016-09-09jQuery $.each遍歷對(duì)象、數(shù)組用法實(shí)例
這篇文章主要介紹了jQuery $.each遍歷對(duì)象、數(shù)組用法實(shí)例,本文講解了在有參數(shù)和無(wú)參數(shù)的情況下遍歷對(duì)象及遍歷數(shù)組的例子及each方法的幾種常用用法,需要的朋友可以參考下2015-04-04jquery UI Datepicker時(shí)間控件的使用方法(終結(jié)版)
這篇文章是jquery UI Datepicker時(shí)間控件的使用方法終結(jié)版,可以說(shuō)是技術(shù)的升華,實(shí)現(xiàn)的功能有限制的開始時(shí)間和結(jié)束時(shí)間跨度不超過(guò)三天,并配置有清空時(shí)間,重選時(shí)間等,感興趣的小伙伴們可以參考一下2015-11-11jQuery實(shí)現(xiàn)的Tab滑動(dòng)選項(xiàng)卡及圖片切換(多種效果)小結(jié)
這篇文章主要介紹了jQuery實(shí)現(xiàn)的Tab滑動(dòng)選項(xiàng)卡及圖片切換效果小結(jié),實(shí)例總結(jié)了幾種常見的tab切換效果,包括鼠標(biāo)點(diǎn)擊切換、滑過(guò)切換、定時(shí)自動(dòng)切換等,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-09-09為jQuery.Treeview添加右鍵菜單的實(shí)現(xiàn)代碼
jquery.treeview 數(shù)據(jù)通過(guò)JSON數(shù)據(jù)加載,有需要的朋友,可以通jquery的AJAX方法獲取相關(guān)的JSON數(shù)據(jù)。2010-10-10