<?xml version="1.0" encoding="UTF-8"?>
<!-- generator="ARTICLE @ XOOPS powered by FeedCreator" -->
<rss version="0.91">
    <channel>
        <title>睡蓮‧池水間 :: 文章</title>
        <description><![CDATA[文章XML]]></description>
        <link>http://waterlily-lsl.com/modules/article/view.article.php/224/c2</link>
        <lastBuildDate>Thu, 24 May 2012 01:32:11 +0200</lastBuildDate>
        <generator>ARTICLE @ XOOPS powered by FeedCreator</generator>
        <image>
            <url>http://waterlily-lsl.com/modules/article/images/logo.png</url>
            <title>睡蓮‧池水間 :: 文章</title>
            <link>http://waterlily-lsl.com/modules/article/</link>
            <width>92</width>
            <height>52</height>
            <description>文章XML</description>
        </image>
        <language>zh-TW</language>
        <managingEditor>waterlily at waterlily-lsl dot com</managingEditor>
        <webMaster>waterlily at waterlily-lsl dot com</webMaster>
        <category>文章</category>
        <item>
            <title>CSS 3 變換入門</title>
            <link>http://waterlily-lsl.com/modules/article/view.article.php/224/c2</link>
            <description><![CDATA[類別: 語言集<br />來源: (http://www.webdesignerdepot.com/2010/01/css-transitions-101/)<div class="article-source"><span class="article-label">本文譯者：</span><span class="article-content">神飛</span>　　<span class="article-label">譯文出處：</span><span class="article-content">前端觀察 - &#104;&#116;&#116;&#112;&#58;&#47;&#47;www&#46;qianduan.net/css-transitions-101&#46;html</span></div><br /><br /><br />　　儘管人們期望在屏幕上有些改變，但是 CSS 和 HTML 對頁面中的交互能做的實在太少了，而那些還需要用代碼來實現。 <br /><br />　　比如一個鏈接要麼是這個顏色，要麼是那個顏色；一個文本區域要麼這麼大，要麼那麼大；一張圖片要麼是透明的要麼是不透明的；它們是從一個狀態直接變到另一個狀態<strong class="A_strong">——中間並沒有過渡</strong>。 <br /><br />　　這導致大部分網頁有些生硬，因為元素只會很死板的切換或改變。 <br /><br />　　是的，你可以使用 DHTML、jQuery 或者自己編寫 JS 來實現過度，但是這需要更多的代碼來實現本應該非常簡單的功能。 <br /><br />　　我們需要的是快速而簡單的方法來給頁面添加簡單的變換(transition)效果。在本文中，你會發現很有用的關於 <strong class="A_strong">CSS 變換(transition)</strong>以及如何使用它們的信息。 <br /><br />　　幾個月之前，我就<a href="http://www.webdesignerdepot.com/2009/08/5-css3-design-enhancements-that-you-can-use-today/" rel="external">建議設計師應該開始使用新的 CSS 3 技術</a>來實現一些它們渴求已久的基本的功能了——唯一的問題就是，這些技術沒有一個能在 IE 中可用，包括 IE8 。 <br /><br />　　一些讀者認為的那些技術將會有 75% 的用戶看不到的觀點是不靠譜的。 <br /><br />　　對那些讀者我想說，“坐穩了”，因為我將要向你介紹另一個新的 CSS 屬性，它允許你通過簡單的幾行代碼來為任意元素添加很酷的變換效果。 <br /><br />　　CSS 變換剛剛在 CSS 3 中被引入，但是已經被添加為 webkit 的擴展了。也就是說，現在它們只能用於基於 webkit 內核的瀏覽器，包括 Apple Safari 和 Google Chrome。不過從 Opera 10.5 pre-Alpha 版本來看，Opera 將在下一個 10.5 中支持 CSS 3 變換。所以<span style="color: #ffac00;">要看到本文中提到的實際效果，強烈建議你使用 Chrome 或者 Safari 4 來查看本文</span>。<br /><br /><h3 id="heading1"><span style="text-decoration:underline">CSS 變換從哪裡來？</span></h3><br />　　變換曾經只是 Webkit 的一部分，而且是 Safari UI 能做而其它瀏覽器不能實現的一些很酷的東東的基礎。 <br /><br />　　但是 W3C CSS 工作組曾經拒絕將變換添加到它的官方特性裡面，一些成員堅持認為變換並非 CSS 屬性而通過腳本來處理會更好。 <span style="color: #9d6c9a;">(內牛滿面啊，我前一段也有類似的觀點，也和高溫討論過，我認為 CSS 動畫超出了表現的範圍，交互的東西應該有腳本來實現，不過後來在鬼哥的點撥下，才開始有了新的認識——神飛)</span> <br /><br />　　但是很多設計師和開發人員，包括我自己，堅持認為這確實是樣式——只是<strong class="A_strong">動態</strong>樣式，而不是我們日常使用的傳統的靜態樣式。 <br /><br />　　幸運的是，關於動態樣式的爭論已經成為過去。去年三月份，來自 Apple 和 Mozilla 的代表們開始<a href="http://www.w3.org/TR/css3-transitions/" rel="external">將CSS變換模塊添加到 CSS 3 特性裡面</a>，非常接近 Apple 已經添加到 webkit 中的表現。<br /><br /><h3 id="heading2"><span style="text-decoration:underline">關於設計增強的一個簡要介紹</span></h3><br />　　在我們繼續之前，讓我強調一點：永遠不要讓網站的功能依賴樣式，如果該樣式不是瀏覽器通用的話(也就是說，所有的常用瀏覽器都支持)。<br /><br />　　對錯過的同學再一次強調：<strong class="A_strong">永遠不要讓網站的功能依賴樣式，如果該樣式不是瀏覽器通用的話</strong>。<br /><br />　　這也就是說，你可以使用樣式，比如變換，作為設計增強以提高用戶體驗——在不犧牲看不到它們的用戶的可用性的前提下。如果你不用 CSS 變換照樣能用而且用戶依然能夠完成他們的任務，就沒問題，你就可以使用 CSS 變換。<br /><br /><h3 id="heading3"><span style="text-decoration:underline">首先，一些變換的想法</span></h3><br />　　CSS 變換將不會替代所有的 DHTML，不過它會提供一些支持過渡的方法來提高您在瀏覽器中的設計。<br /><br />　　你需要到下載 <a href="http://www.apple.com/safari/" rel="external">Apple Safari 3+</a> 或 <a href="http://www.google.com/chrome" rel="external">Google Chrome</a> 瀏覽器來查看這些變換效果。這兩個瀏覽器都支持 Mac 和 PC 系統。<br /><br /><h3 id="heading4"><span style="text-decoration:underline">滾動效果</span></h3><br />　　變換最常見的用法就是當用戶的鼠標懸放到元素上的時候將元素高亮(無論是鏈接、表格、表單還是其它的什麼元素)，變換是為頁面添加平滑的界面的非常棒的方法。<br /><br />  <strong class="A_strong">例一</strong><br /><div id="example1" class="example"><p><a href="#">Link</a></p></div><br /><h3 id="heading5"><span style="text-decoration:underline">下拉菜單</span></h3><br />　　純CSS菜單比較容易實現，而變換還可以讓你給菜單添加下拉和高亮效果。<br /><br />  <strong class="A_strong">例二</strong><br /><div id="example2" class="example"><ul class="menu"><li>About Us</li><ul class="drop"><li><a href="#">Our Team</a></li><li><a href="#">News</a></li><li><a href="#">Reviews</a></li><li><a href="#">Contact</a></li></ul></ul></div><br /><h3 id="heading6"><span style="text-decoration:underline">動畫</span></h3><br />　　你可以在頁面上的兩點之間移動一個對象，然後使用變換給它添加動畫效果。<br /><br /><strong class="A_strong">例三</strong><br /><div id="example3" class="example"><div class="move"><p class="control" style="color: rgb(255, 255, 255);">點擊一下，不要放開!</p><div id="astro"><img src="/uploads/article/images/astro-127531.png" alt="" /></div></div></div><br /><h3 id="heading7"><span style="text-decoration:underline">變換、狀態與動作</span></h3><br />　　但是請稍等一下。在深入了解變換之前，我們需要理解一個元素能變換的不同的狀態。<br /><br />　　狀態定義當前頁面中相應的元素如何與用戶進行交互，它們在CSS中通過偽類來定義，比如當用戶的鼠標經過一個元素的時候，那個元素就會被 hover 偽類控制。<br /><table class="artContable3"><tr><th>動態偽類</th><th>起作用的元素</th><th>描述</th></tr><tr><td>:link</td><td>只有鏈接</td><td>未訪問的鏈接</td></tr><tr><td>:visited</td><td>只有鏈接</td><td>訪問過的鏈接</td></tr><tr><td>:hover</td><td>所有元素</td><td>鼠標經過元素</td></tr><tr><td>:active</td><td>所有元素</td><td>鼠標點擊元素</td></tr><tr><td>:focus</td><td>所有可被選中的元素</td><td>元素被選中</td></tr><tr><td>None</td><td>所有元素</td><td>所有元素的默認狀態</td></tr></table><br />　　變換通過改變不同元素狀態之間的一個時間段內的樣式來起作用。比如，一個元素的默認狀態的顏色值將會在呈現 hover 狀態的色彩值之前逐漸顯示色盤中的中間顏色。<br /><br /><h3 id="heading8"><span style="text-decoration:underline">一個簡單的變換</span></h3><br />　　讓我們假設一個簡單的變換，在用戶的鼠標經過一個鏈接的時候，將顏色從一個變換成另外一個。與其它 CSS 屬性一樣，變換也是直接添加到要使用它的選擇器中。該屬性可以採用下面的 4 個值。<br /><br /><strong class="A_strong">CSS property</strong><br /><br />　　被變換的屬性(比如, color)。看一下下面的表格了解所有可以被變換的CSS屬性列表。<br /><br /><strong class="A_strong">Duration</strong><br /><br />　　變換持續的時間，通常以秒來計算(比如, .25s).<br /><br /><strong class="A_strong">Timing function</strong><br /><br />　　允許你控制持續的時間的計算方式。與其使用一個簡單的線性計算，你可以使變換加速(漸入)或者減速(淡出)，或者甚至 specify a beat or count (比如，linear). More on this later in the article.<br /><br /><strong class="A_strong">Delay</strong><br /><br />　　在動作和變換開始之間等待多久，通常用秒來表示(比如, .1s)。如果你不想延遲，該值可省略。<br /><br />　　因為變換屬性始於Webkit擴展，我們不得不同時使用transition 和-webkit-transition 屬性以向後兼容。<br /><br />　　讓我們首先提阿賈這這些屬性到 :hover 偽類中:<br /><div class="xoopsCode"><p class="cTitle"><img class="icon-l" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon1.gif" alt=""/><img class="icon-r" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon2.gif" alt=""/></p><pre>a:hover {
   color: red;
   -webkit-transition: color .25s linear;
   transition: color .25s linear;
}</pre></div><br />　　那麼現在，當鼠標經過一個鏈接，不會直接從藍色跳轉到紅色，而是用四分之一秒的時間逐漸變換它們的中間顏色(過渡顏色)。<p style="background:url(/uploads/article/images/CSStransition.jpg) no-repeat 50% 0;height:381px"><!-- image --></p>　　當然，我們也希望變換回到默認的鏈接顏色，那麼我們可以添加一個變換到 :link (以及 :visited)偽類上，並在它褪去之前添加一個簡單的延遲(十分之一秒) :<br /><div class="xoopsCode"><p class="cTitle"><img class="icon-l" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon1.gif" alt=""/><img class="icon-r" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon2.gif" alt=""/></p><pre>a:link, a:visited {
   color: blue;
   -webkit-transition: color .25s linear .1s;
   transition: color .25s linear .1s;
}</pre></div><br /><h3 id="heading9"><span style="text-decoration:underline">添加多重變換</span></h3><br />　　因為一個變換就是一個 CSS 屬性，如果你在同一個 CSS 規則中添加多個變換的實例，那麼最後的那個將會覆蓋前面的，而不是添加它們。所以在下面的規則中，唯一的變換將是背景色彩：<br /><div class="xoopsCode"><p class="cTitle"><img class="icon-l" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon1.gif" alt=""/><img class="icon-r" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon2.gif" alt=""/></p><pre>a:hover {
  color: red;
  background-color: rgb(235,235,185);
  -webkit-transition: color .25s linear;
  transition: color .25s linear;
  -webkit-transition: background-color .15s linear .1;
  transition: background-color .15s linear .1;
}</pre></div><br />　　當然，這並不是說，不能添加多重變換——多重變換可以在同一個變換屬性定義中用逗號隔開：<br /><div class="xoopsCode"><p class="cTitle"><img class="icon-l" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon1.gif" alt=""/><img class="icon-r" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon2.gif" alt=""/></p><pre>a:hover {
  color: red;
  background-color: rgb(235,235,185);
   -webkit-transition: color .25s linear, background-color .15s linear .1s;
  transition: color .25s linear, background-color .15s linear .1s;
 }</pre></div><br />　　這條定義將產生色彩和背景色的雙重變換。<br /><br /><h3 id="heading10"><span style="text-decoration:underline">什麼可以被變換？</span></h3><br />　　幾乎所有的有色彩、大小或位置等組件的 CSS 屬性，包括許多新添加的CSS 3屬性，都可以應用變換。一個值得注意的例外是 box-shadow。<br /><br />　　來自 W3C 的變換的說明，這裡是一個可以賦予變換的 CSS 屬性的列表，附帶轉變的對象，我也高亮了一些比較有用的屬性。<br /><table class="artContable3"><tr><th>CSS屬性</th><th>改變的對象</th></tr><tr><td><strong class="A_strong">background-color</strong></td><td><strong class="A_strong">色彩</strong></td></tr><tr><td>background-image</td><td>只是漸變</td></tr><tr><td>background-position</td><td>百分比，長度</td></tr><tr><td>border-bottom-color</td><td>色彩</td></tr><tr><td>border-bottom-width</td><td>長度</td></tr><tr><td><strong class="A_strong">border-color</strong></td><td><strong class="A_strong">色彩</strong></td></tr><tr><td>border-left-color</td><td>色彩</td></tr><tr><td>border-left-width</td><td>長度</td></tr><tr><td>border-right-color</td><td>色彩</td></tr><tr><td>border-right-width</td><td>長度</td></tr><tr><td>border-spacing</td><td>長度</td></tr><tr><td>border-top-color</td><td>色彩</td></tr><tr><td>border-top-width</td><td>長度</td></tr><tr><td>border-width</td><td>長度</td></tr><tr><td><strong class="A_strong">bottom</strong></td><td><strong class="A_strong">百分比，長度</strong></td></tr><tr><td><strong class="A_strong">color</strong></td><td><strong class="A_strong">色彩</strong></td></tr><tr><td>crop</td><td>百分比</td></tr><tr><td><strong class="A_strong">font-size</strong></td><td><strong class="A_strong">百分比，長度</strong></td></tr><tr><td><strong class="A_strong">font-weight</strong></td><td><strong class="A_strong">數字</strong></td></tr><tr><td>grid-*</td><td>數量</td></tr><tr><td><strong class="A_strong">height</strong></td><td><strong class="A_strong">百分比，長度</strong></td></tr><tr><td><strong class="A_strong">left</strong></td><td><strong class="A_strong">百分比，長度</strong></td></tr><tr><td><strong class="A_strong">letter-spacing</strong></td><td><strong class="A_strong">長度</strong></td></tr><tr><td>line-height</td><td>百分比，長度，數字</td></tr><tr><td>margin-bottom</td><td>長度</td></tr><tr><td>margin-left</td><td>長度</td></tr><tr><td>margin-right</td><td>長度</td></tr><tr><td>margin-top</td><td>長度</td></tr><tr><td>max-height</td><td>百分比，長度</td></tr><tr><td>max-width</td><td>百分比，長度</td></tr><tr><td>min-height</td><td>百分比，長度</td></tr><tr><td>min-width</td><td>百分比，長度</td></tr><tr><td><strong class="A_strong">opacity</strong></td><td><strong class="A_strong">數字</strong></td></tr><tr><td>outline-color</td><td>色彩</td></tr><tr><td>outline-offset</td><td>整數</td></tr><tr><td>outline-width</td><td>長度</td></tr><tr><td>padding-bottom</td><td>長度</td></tr><tr><td>padding-left</td><td>長度</td></tr><tr><td>padding-right</td><td>長度</td></tr><tr><td>padding-top</td><td>長度</td></tr><tr><td><strong class="A_strong">right</strong></td><td><strong class="A_strong">百分比，長度</strong></td></tr><tr><td>text-indent</td><td>百分比，長度</td></tr><tr><td><strong class="A_strong">text-shadow</strong></td><td><strong class="A_strong">陰影</strong></td></tr><tr><td><strong class="A_strong">top</strong></td><td><strong class="A_strong">百分比，長度</strong></td></tr><tr><td>vertical-align</td><td>百分比，長度，關鍵詞</td></tr><tr><td>visibility</td><td>可見性</td></tr><tr><td><strong class="A_strong">width</strong></td><td><strong class="A_strong">百分比，長度</strong></td></tr><tr><td>word-spacing</td><td>百分比，長度</td></tr><tr><td>z-index</td><td>正整數</td></tr><tr><td>zoom</td><td>數字</td></tr></table><br /><h3 id="heading11"><span style="text-decoration:underline">變換計時與延遲</span></h3><br />　　使用變換，你可以改變變換的速率，在開始的時候較慢然後在結束的時候加速，反之亦然，或者之間的任何事情。 CSS 變換有 5 個計時的關鍵詞，同時也允許你自己定義你自己的計時曲線。<br /><table class="artContable3"><tr><th>名稱</th><th>如何工作</th></tr><tr><td>cubic-bezier(x1, y1, x2, y2)</td><td>X 和 Y 值在 0 到 1 之間，以定義用於 Time function 的貝塞爾曲線的形狀。</td></tr><tr><td>linear</td><td>均速</td></tr><tr><td>ease</td><td>逐漸慢下來</td></tr><tr><td>ease-in</td><td>加速(漸入)</td></tr><tr><td>ease-out</td><td>減速(淡出)</td></tr><tr><td>ease-in-out</td><td>加速然後減速</td></tr></table><br /><h3 id="heading12"><span style="text-decoration:underline">全部變換？</span></h3><br />　　變換將很快成為所有網站的標準操作方式，從而增強用戶界面的體驗。<br /><br />　　為了給你的整個網站添加一個普遍的變換，一個做法就是添加一個變換到全體選擇器，類似 CSS reset。下面的代碼會給頁面中的所有元素添加一個默認的變換，從而允許你保持一個統一的變換效果：<br /><div class="xoopsCode"><p class="cTitle"><img class="icon-l" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon1.gif" alt=""/><img class="icon-r" src="http://waterlily-lsl.com/themes/waterlilyLSL-GW/img/code-icon2.gif" alt=""/></p><pre>*:link, *:visited, *:hover, *:active, *:focus {
-webkit-transition:
	color .25s linear,
	background-color .25s linear,
	border-color .25s linear;
transition:
	color .25s linear,
	background-color .25s linear,
	border-color .25s linear;
}</pre></div><br />　　一個反對全部變換，同時明確反對使用全體選擇器作為 CSS reset 的爭論是，將一個樣式用到頁面的所有元素會減緩頁面的渲染。然而，我並沒有發現任何有關與此的證據。有人知道嗎？ <br /><br />　　OK，其實 CSS 變換就這麼簡單，它並不難理解，而且你也不用些大量的 JS 腳本來實現它，這很方便實用，多做幾次練習，你就可以熟練的使用它了。<br /><p style="font-size:13px;line-height:19px;color:#9d6c9a;padding-top:50px">譯註：本文原文題目為 CSS transitions 101，101 這個數字比較不好理解，其實美國大學第一門課程通常編號為 101，所以 101 一般表示入門、初級的意思。另外關於 transition 這個詞的翻譯，我之前是翻譯成“轉換”，但是這個翻譯很彆扭，在 twitter 上和 @gaowhen、@ghostzhang、@ivane、@hiwanz、@cnjoel 等人討論後，覺得翻譯成“變換”更合適一些，多謝各位。 —— 神飛</p><br />]]></description>
            <author>睡蓮</author>
            <pubDate>Tue, 02 Feb 2010 01:32:56 +0200</pubDate>
        </item>
    </channel>
</rss>

