css3 transform transition相關問題
問題描述
<style> .a{-webkit-transition: 1s 0s all ease;-o-transition: 1s 0s all ease;-moz-transition: 1s 0s all ease;transition: 1s 0s all ease;-webkit-transform: scale(1.1,1.1);-o-transform: scale(1.1,1.1);-moz-transform: scale(1.1,1.1);transform: scale(1.1,1.1); }</style><p style='height: 300px;width: 300px;background: red'></p>
就這樣 為什么頁面顯示出來直接放大了1.1倍 1秒的過濾怎么就沒有?
問題解答
回答1:既然是過渡,就應該有一個狀態的變化,題主這樣設置就是讓.a的初始狀態就為1.1倍。如果你給.a:hover設置樣式就可以看到效果了:
.a { -webkit-transition: 1s 0s all ease; -o-transition: 1s 0s all ease; -moz-transition: 1s 0s all ease; transition: 1s 0s all ease;}.a:hover { -webkit-transform: scale(1.1, 1.1); -o-transform: scale(1.1, 1.1); -moz-transform: scale(1.1, 1.1); transform: scale(1.1, 1.1);}
題主如果是想要一加載就開始動畫的話,應該使用animation來實現。
回答2:我猜題主想要的可能是這種效果?不過這個應該算動畫不算過渡吧www
<!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.0 Transitional//EN' ''> <html xmlns=''> <head> <meta http-equiv='Content-Type' content='text/html; charset=gb2312' /> <style> @keyframes myfirst{ from {background: red;} to {background: yellow;-webkit-transform: scale(1.1,1.1);-o-transform: scale(1.1,1.1);-moz-transform: scale(1.1,1.1);transform: scale(1.1,1.1); } } @-moz-keyframes myfirst /* Firefox */{ from {background: red;} to {background: yellow;-webkit-transform: scale(1.1,1.1);-o-transform: scale(1.1,1.1);-moz-transform: scale(1.1,1.1);transform: scale(1.1,1.1); } } @-webkit-keyframes myfirst /* Safari 和 Chrome */{ from {background: red;} to {background: yellow;-webkit-transform: scale(1.1,1.1);-o-transform: scale(1.1,1.1);-moz-transform: scale(1.1,1.1);transform: scale(1.1,1.1); } } @-o-keyframes myfirst /* Opera */{ from {background: red;} to {background: yellow;-webkit-transform: scale(1.1,1.1);-o-transform: scale(1.1,1.1);-moz-transform: scale(1.1,1.1);transform: scale(1.1,1.1); } } .a{ width: 300px; height: 300px; background: red; -webkit-animation: myfirst 1s; -o-animation: myfirst 1s; -moz-animation: myfirst 1s; animation: myfirst 1s; } </style> </head> <body> <p class='a'></p></body> </html> 回答3:
W3C標準中對css3的transition這是樣描述的: “css的transition允許css的屬性值在一定的時間區間內平滑地過渡。這種效果可以在鼠標單擊、獲得焦點、被點擊或對元素任何改變中觸發,并圓滑地以動畫效果改變CSS的屬性值?!彼圆⒉皇鞘裁磿r候都能看到動畫效果的,在頁面剛加載 解析css 渲染頁面的時候 并沒有觸發過渡效果。如果想實現頁面剛加載就出發 transition 的效果的話,可以考慮 用一下 調用一次 animation;或者 用js 獲取頁面加載狀態;
僅供參考...
相關文章:
1. angular.js - angular ng-class里面的引號問題2. javascript - 奇怪的Symbol的問題3. javascript - Web微信聊天輸入框解決方案4. docker - 如何修改運行中容器的配置5. javascript - 有沒有什么好的圖片懶加載的插件,需要包含監聽頁面滾動高度,然后再加載的功能6. javascript - history.replaceState()無法改變query參數7. html - vue項目中用到了elementUI問題8. matplotlib - python函數的問題9. mysql無法添加外鍵10. javascript - react 中綁定事件和阻止事件冒泡
