JQuery插件Style定制化方法的分析與比較
更新時間:2012年05月03日 20:17:13 作者:
最近因?yàn)轫?xiàng)目的需要,使用了一個JQuery插件。把插件下下來后,很快我就發(fā)現(xiàn),很多默認(rèn)的插件Style不符合項(xiàng)目要求,必須要被修改
1前言
最近因?yàn)轫?xiàng)目的需要,使用了一個JQuery插件。把插件下下來后,很快我就發(fā)現(xiàn),很多默認(rèn)的插件Style不符合項(xiàng)目要求,必須要被修改。
在這個過程中,我發(fā)現(xiàn)自己先后使用了多種不同的方法實(shí)現(xiàn)插件Style的定制化。很高興最后找到了我認(rèn)為最好的方法,對CSS的認(rèn)識也加深了不少,感觸頗多。這篇文章就是對這些新的CSS的認(rèn)識的一個梳理。
2JQuery 插件Style 定制化方法
2.1 初始化插件時輸入定制化對象
做的比較好的插件會在初始化時允許輸入定制化對象。
如果輸入定制化對象,插件會使用定制化對象中的值,例如,
var adgallerySetting = {
width: 600, // Width of the image, set to false and it will read the CSS width
height: 400, // Height of the image, set to false and it will read the CSS height
}
var galleries = $('.ad-gallery').adGallery(adgallerySetting);
如果不輸入定制化對象,插件會使用它自己的默認(rèn)值,例如,
var galleries = $('.ad-gallery').adGallery();
2.2 修改插件的CSS
如果插件沒有提供定制化對象或你想要修改的Style不在定制化對象定義里,一個比較直觀的方法是修改插件的CSS文件。這不是一種值得提倡的方法,因?yàn)檫@會Corrupt插件的本身的源代碼,且不利于以后插件版本的更新。
2.3 注冊Callback函數(shù)
大部分插件還在定制化對象里定義Callback函數(shù)。如果Callback函數(shù)在插件完成style enhance后調(diào)用,你可以寫這個Callback并注冊,在Callback里修改DOM模型,從而完成插件style的定制化。這種方法比較繁瑣,需要你花比較多的時間去理解插件內(nèi)部的實(shí)現(xiàn)。例如,
var adgallerySetting = {
// All callbacks has the AdGallery objects as 'this' reference
callbacks: {
// This gets fired right before old_image is about to go away, and new_image
// is about to come in
beforeImageVisible: function(new_image, old_image) {
// Do something wild!
var thing = "this is it";
//Change the plugin enhanced page
$(".ad-gallery .ad-image-wrapper .ad-image").removeAttr("style");
$(".ad-gallery .ad-image-wrapper .ad-image").css("width", "100%");
var width = $(".ad-gallery .ad-image-wrapper .ad-image img").attr("width");
$(".ad-gallery .ad-image-wrapper .ad-image img").attr("width", "100%");
$(".ad-gallery .ad-image-wrapper .ad-image .img").attr("width", 100%);
$(".ad-gallery .ad-image-wrapper .ad-image").attr("height", 100%);
}
}
};
2.4 增加一個新的CSS文件,重載插件的部分style
CSS是cascading style sheet 的縮寫,固名思義,它有一個Cascading 標(biāo)準(zhǔn)。當(dāng)多個CSS 文件對同一個HTML element的style定義有沖突時,它會根據(jù)以下規(guī)則決定apply哪個CSS style.
1) ! Important 標(biāo)識。
2) 來源。 Author (HTMl鏈入的CSS文件), Reader(Web surfer), User agent(Browser)
3) 相關(guān)性。
具體可以查看參考部分的鏈接網(wǎng)頁。
這種方法,在我看來是除1.1 外最好的方法,下面是些代碼示例。
#descriptions .ad-image-description {
position: absolute;
}
#descriptions .ad-image-description .ad-description-title {
display: block;
}
.ad-gallery .ad-image-wrapper .ad-image {
width: 100% ! important;
left: 0px ! important;
}
3總結(jié)
根據(jù)這次的經(jīng)驗(yàn),我覺得定制插件Style的最好方法輸入定制化對象(如果插件支持的話)或CSS重載。有些插件會以在HTML element中加入style="...."的方式定義style。在這種情況下,你就會發(fā)現(xiàn),“! important”標(biāo)識的出現(xiàn)是相當(dāng)?shù)牧钊耸嫘?。J
4參考
http://www.w3.org/TR/CSS21/cascade.html
http://stackoverflow.com/questions/7022344/css-newbie-questions-on-authors-style-readers-style-agents-style
http://htmlhelp.com/reference/css/structure.html
http://css-tricks.com/override-inline-styles-with-css/
最近因?yàn)轫?xiàng)目的需要,使用了一個JQuery插件。把插件下下來后,很快我就發(fā)現(xiàn),很多默認(rèn)的插件Style不符合項(xiàng)目要求,必須要被修改。
在這個過程中,我發(fā)現(xiàn)自己先后使用了多種不同的方法實(shí)現(xiàn)插件Style的定制化。很高興最后找到了我認(rèn)為最好的方法,對CSS的認(rèn)識也加深了不少,感觸頗多。這篇文章就是對這些新的CSS的認(rèn)識的一個梳理。
2JQuery 插件Style 定制化方法
2.1 初始化插件時輸入定制化對象
做的比較好的插件會在初始化時允許輸入定制化對象。
如果輸入定制化對象,插件會使用定制化對象中的值,例如,
復(fù)制代碼 代碼如下:
var adgallerySetting = {
width: 600, // Width of the image, set to false and it will read the CSS width
height: 400, // Height of the image, set to false and it will read the CSS height
}
var galleries = $('.ad-gallery').adGallery(adgallerySetting);
如果不輸入定制化對象,插件會使用它自己的默認(rèn)值,例如,
var galleries = $('.ad-gallery').adGallery();
2.2 修改插件的CSS
如果插件沒有提供定制化對象或你想要修改的Style不在定制化對象定義里,一個比較直觀的方法是修改插件的CSS文件。這不是一種值得提倡的方法,因?yàn)檫@會Corrupt插件的本身的源代碼,且不利于以后插件版本的更新。
2.3 注冊Callback函數(shù)
大部分插件還在定制化對象里定義Callback函數(shù)。如果Callback函數(shù)在插件完成style enhance后調(diào)用,你可以寫這個Callback并注冊,在Callback里修改DOM模型,從而完成插件style的定制化。這種方法比較繁瑣,需要你花比較多的時間去理解插件內(nèi)部的實(shí)現(xiàn)。例如,
復(fù)制代碼 代碼如下:
var adgallerySetting = {
// All callbacks has the AdGallery objects as 'this' reference
callbacks: {
// This gets fired right before old_image is about to go away, and new_image
// is about to come in
beforeImageVisible: function(new_image, old_image) {
// Do something wild!
var thing = "this is it";
//Change the plugin enhanced page
$(".ad-gallery .ad-image-wrapper .ad-image").removeAttr("style");
$(".ad-gallery .ad-image-wrapper .ad-image").css("width", "100%");
var width = $(".ad-gallery .ad-image-wrapper .ad-image img").attr("width");
$(".ad-gallery .ad-image-wrapper .ad-image img").attr("width", "100%");
$(".ad-gallery .ad-image-wrapper .ad-image .img").attr("width", 100%);
$(".ad-gallery .ad-image-wrapper .ad-image").attr("height", 100%);
}
}
};
2.4 增加一個新的CSS文件,重載插件的部分style
CSS是cascading style sheet 的縮寫,固名思義,它有一個Cascading 標(biāo)準(zhǔn)。當(dāng)多個CSS 文件對同一個HTML element的style定義有沖突時,它會根據(jù)以下規(guī)則決定apply哪個CSS style.
1) ! Important 標(biāo)識。
2) 來源。 Author (HTMl鏈入的CSS文件), Reader(Web surfer), User agent(Browser)
3) 相關(guān)性。
具體可以查看參考部分的鏈接網(wǎng)頁。
這種方法,在我看來是除1.1 外最好的方法,下面是些代碼示例。
復(fù)制代碼 代碼如下:
#descriptions .ad-image-description {
position: absolute;
}
#descriptions .ad-image-description .ad-description-title {
display: block;
}
.ad-gallery .ad-image-wrapper .ad-image {
width: 100% ! important;
left: 0px ! important;
}
3總結(jié)
根據(jù)這次的經(jīng)驗(yàn),我覺得定制插件Style的最好方法輸入定制化對象(如果插件支持的話)或CSS重載。有些插件會以在HTML element中加入style="...."的方式定義style。在這種情況下,你就會發(fā)現(xiàn),“! important”標(biāo)識的出現(xiàn)是相當(dāng)?shù)牧钊耸嫘?。J
4參考
http://www.w3.org/TR/CSS21/cascade.html
http://stackoverflow.com/questions/7022344/css-newbie-questions-on-authors-style-readers-style-agents-style
http://htmlhelp.com/reference/css/structure.html
http://css-tricks.com/override-inline-styles-with-css/
相關(guān)文章
jQuery中clone()函數(shù)實(shí)現(xiàn)表單中增加和減少輸入項(xiàng)
這篇文章給大家介紹了jQuery中clone()函數(shù)實(shí)現(xiàn)表單中增加和減少輸入項(xiàng)的實(shí)例代碼,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2017-05-05jquery中實(shí)現(xiàn)時間戳與日期相互轉(zhuǎn)換
本文主要利用jquery擴(kuò)展寫了一個myTime對象,并寫了2個函數(shù)分別處理日期和時間戳之間的相互轉(zhuǎn)換。2016-04-04jQuery基礎(chǔ)的工廠函數(shù)以及定時器的經(jīng)典實(shí)例分析
下面小編就為大家?guī)硪黄猨Query基礎(chǔ)的工廠函數(shù)以及定時器的經(jīng)典實(shí)例分析。小編覺得挺不錯的,現(xiàn)在2016-05-05jquery對標(biāo)簽添加只讀(readonly)或者禁用(disabled)屬性
這篇文章主要介紹了jquery對標(biāo)簽添加只讀(readonly)或者禁用(disabled)屬性,jQuery是一個JavaScript庫。極大地簡化了JavaScript編程,下面關(guān)于其詳細(xì)介紹,需要的小伙伴可以參考一下2022-03-03jQuery學(xué)習(xí)7 操作JavaScript對象和集合的函數(shù)
jQuery學(xué)習(xí)7:操作JavaScript對象和集合的函數(shù)2010-02-02jQuery動態(tài)創(chuàng)建元素以及追加節(jié)點(diǎn)的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄猨Query動態(tài)創(chuàng)建元素以及追加節(jié)點(diǎn)的實(shí)現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10jQuery中[attribute]選擇器用法實(shí)例
這篇文章主要介紹了jQuery中[attribute]選擇器用法,以實(shí)例形式分析了[attribute]選擇器的功能、定義及匹配給定元素屬性的技巧,具有一定的參考借鑒價值,需要的朋友可以參考下2014-12-12