DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> WEB網站前端 >> 前端技巧 >> 分享5個有幫助的CSS選擇器豐富你的CSS經驗
分享5個有幫助的CSS選擇器豐富你的CSS經驗
編輯:前端技巧     
通過網頁設計師的大量CSS經驗,我們會記住所有種代碼語法,兼容性和片段。有一些特定的CSS,可以真正幫助改變你的網站設計改變較舊的技術規則和聲明,使用更少的代碼寫出同樣的效果是我們一直不斷追求的目標
以下是5 個CSS選擇器將幫助您保持您的XHTML頁面更加干淨
1、匹配子類
在設計菜單有時你需要選擇具有多個類的元素,如選擇“item”和“active”的所有元素:

復制代碼代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<style>
/* styles here */
</style>
</head>
<body>
<ul class="list">
<li class="item">item 1</li>
<li class="item active">active item 2</li>
<li class="active">item 3</li>
</ul>
</body>
</html>

典型的解決方案是使用父元素,例如:
.list .item {color: #ccc;} / *所有的元素'item'類* /
.list .active {text-decoration: underline;} /* *所有的元素“item”和“active”類**/
但是,如果你需要排除“active”類的元素,但離開“item“,該怎麼辦呢?這裡是子集匹配選擇器代碼:

復制代碼代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<style>
.item {color: #ccc;} /* all elements with 'item' class */
.item.active {text-decoration: underline;} /* all element with 'item' and 'active' class */
</style>
</head>
<body>
<ul>
<li class="item">.item CSS selector applied</li>
<li class="item active">.item and .item.active CSS selectors applied </li>
<li class="item active someOneMoreClass">.item and .item.active CSS selectors applied too</li>
<li class="active">no CSS selectors applied</li>
</ul>
</body>
</html>

浏覽器支持:火狐,Chrome,Safari浏覽器,IE 7及以上
2、 屬性選擇
有時,你可能需要匹配元素的特定屬性值. 對我來說最常見的情況是form表單的提交, 例如. 所有文本輸入元素一個應用樣式,提交按鈕另一種樣式風格遇到這種問題我見到最多的就是給inputs定義一個不同的樣式,像下面的例子:

復制代碼代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<style>
label {display: block; color: #444;}
input.text {border: 1px solid #ccc; color: #333; padding: 3px;}//給文本框定義另外一個類
input.submit {color: #333; border: 1px solid #333; background-color: #eee;}//給提交按鈕定義一個類
</style>
</head>
<body>
<form>
<label for="login">Login</label>
<input class="text" type="text" name="login" id="login" value="" />
<label for="login">Password</label>
<input class="text" type="password" name="password" id="password" value="" />

<input class="submit" type="submit" value="Push me" />
</form>
</body>
</html>

上面寫的確實是對的, 但我有一個解決方案,無需額外定義類, 對於這個問題,我將使用屬性選擇器:

復制代碼代碼如下:
/* 匹配任何一個元素的“name”屬性集(任何值) */
a[name] { ... styles ..}
/* 匹配任何INPUT元素為“type”為屬性值“text */
input[type="text"] { ... styles ..}
/* 匹配任何DIV元素,其的“myattribute”屬性值是一個空格分隔的值列表, 其中一個是完全等於“value3”.
e.g. <div myattribute="value1 value2 value3 value4"> */
div[myattribute~="value3"] { ... styles ..}
/* 匹配任何DIV元素,其“myattribute”屬性有一個連字符分隔的值.
e.g. <div myattribute="value1-value2-value3-value4"> */
div[myattribute~="value2"] { ... styles ..}

所以使用這些規則可以把代碼寫成這樣的樣式

復制代碼代碼如下:
<style>
label {display: block; color: #444;}
/* all text- and password- inputs */
input[type="text"], input[type="password"] {border: 1px solid #ccc; color: #333; padding: 3px;}
/* just submit buttons */
input[type="submit"] {color: #333; border: 1px solid #333; background-color: #eee;}
</style>
<form>
<label for="login">Login</label>
<input type="text" name="login" id="login" value="" />
<label for="password">Password</label>
<input type="password" name="password" id="password" value="" />

<input type="submit" value="Push me" />
</form>

浏覽器支持:火狐,Chrome,Safari浏覽器,IE 7及以上.
3、 相鄰的選擇器
你可能會面臨的另一個問題是元素在同一水平上 應用樣式的(像 將鼠標指針放在項目上看菜單效果):

復制代碼代碼如下:
/* 匹配在同級元素一個“active”類之前任何一個元素* */
a.active + a
/* 匹配在同級元素一個“active”類之後的任何一個元素**/
a + a.active
/* ... and some useful tips ... */
/* 匹配除最後一個外的所有li元素*/
li + li { .. style .. }
/* 匹配 A:hover 的第一個元素 */
a:hover { /* 第一個樣式: 懸停元素 */ }
/* 除了第一個懸停元素的樣式
*/
a + a:hover { .. styles .. }

它可以被用於例如​​菜單上的樣式等。
下面是利用相鄰選擇器更容易的方式:

復制代碼代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<style>
.menu a {
/* 菜單項的樣式 */
border: 1px solid #888;
padding: 3px 10px;
color: #333;
background-color: #fff;
text-decoration: none;
margin: 0;
float: left;
z-index: 1;
position: relative;
}
.menu a:hover {
z-index: 10000;
position: relative;
padding: 8px 20px 8px 20px;
background-color: #aed8fb;
border-left: 1px solid #888;
margin: -5px -10px 0 -10px;
}
.menu a + a:hover {
margin-right: -10px;
margin-left: -11px;
}
.menu a + a {
border-left: none;
}
.menu .clear {
float: none;
clear: both;
}
</style>
</head>
<body>
<div class="menu">
<a href="#">Item 1</a>
<a href="#">Item 2</a>
<a href="#">Item 3</a>
<a href="#">Item 4</a>
<div class="clear"></div>
</div>
</body>
</html>

浏覽器支持:火狐,Chrome,Safari浏覽器,IE 7及以上
4.、子選擇器
子選擇器匹配元素是一些其他元素的子元素。子選擇器組成是隔開的兩個或多個選擇器">"。
/* 匹配 DIV 元素內的所有 P 元素 */
div > p { .. slyles .. }
div ol>li p { .. styles ..}
如果您想要段落內一些具有內容的 div 中的所有圖像左對齊,下面的代碼是能有幫助的:

復制代碼代碼如下:
<div class="content">
<p>Lorem lorem lorem <img src="/images.jpg" alt="this image should be aligned left" /></p>
<p>Lorem lorem lorem <img src="/images.jpg" alt="this image should be aligned left too" /> Lorem lorem lorem </p>
<img src="/images.jpg" alt="this image shouldn't be aligned left too" />
</div>

您可以執行以下操作:
div.content p > img {float: left;}
浏覽器支持:火狐,Chrome,Safari浏覽器,IE 7及以上.
5、 通用選擇技巧
最後,一​​些有用的技巧。正如你所知道的通用選擇(“*”)可以匹配任何元素,如果結合其他選擇,在一些地方也能是有用的。
例如:

復制代碼代碼如下:
/ *匹配所有元素的“href”屬性* /
*[href] { .. styles ..}
/ *匹配的所有元素'alt'為空的屬性* /
*[alt=""]
/* Matches all P elements which are grandchild (not direct child) of DIV element */
div * p { .. styles ..}

浏覽器支持:火狐,Chrome,Safari浏覽器,IE 7及以上.
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved