色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

css3 - 為什么運行動畫后,原本居中的位置卻發生了偏移?

瀏覽:97日期:2023-06-23 15:07:21

問題描述

為什么運行動畫后,原本居中的位置卻發生了偏移?

<!DOCTYPE html><html> <head><meta charset='utf-8'><title></title><style type='text/css'>*{padding: 0px;margin: 0px; } .box1{width: 600px;height: 200px;background: orange;position: relative; } .box1 span{position: absolute;border: 8px solid #fff;border-top: 8px solid transparent;border-radius: 999px;top: 50%;left: 50%;transform: translate(-50%,-50%); } .box1 span:nth-child(1){width: 80px;height: 80px;/*animation: span1 2s linear infinite ;*/ } .box1 span:nth-child(2){width: 40px;height: 40px;/*animation: span2 1s linear infinite ;*/ }@-webkit-keyframes span1{0%{transform: rotate(360deg); opacity: 1;}50%{transform: rotate(180deg); opacity: .5;}100%{transform: rotate(0deg); opacity: 0;} } @-webkit-keyframes span2{0%{transform: rotate(0deg); opacity: .5;}50%{transform: rotate(180deg); opacity: 1;}100%{transform: rotate(360deg); opacity: .5;} } </style> </head> <body><p class='box1'> <span></span> <span></span></p></body>

</html>css3 - 為什么運行動畫后,原本居中的位置卻發生了偏移?

css3 - 為什么運行動畫后,原本居中的位置卻發生了偏移?

問題解答

回答1:

.box1 span:nth-child(1){ width: 80px; height: 80px; animation: span1 2s linear infinite ; margin: -40px 0 0 -40px;}.box1 span:nth-child(2){ width: 40px; height: 40px; animation: span2 1s linear infinite ; margin: -20px 0 0 -20px;}回答2:

這個坑我碰到過,你的定位轉換別用transfrom,改成margin-left:-50%width;用了transfrom他會把初始位置定位到left:50%的地方。

回答3:

transform-origin: center;回答4:

.box1 span{

position: absolute;border: 8px solid #fff;border-top: 8px solid transparent;border-radius: 999px;top: 50%;left: 50%;transform: translate(-50%,-50%);**transform-origin: 0 0;**

}@-webkit-keyframes span1{

0%{transform: rotate(360deg) **translate(-50%,-50%);** opacity: 1;}50%{transform: rotate(180deg) **translate(-50%,-50%);** opacity: .5;}100%{transform: rotate(0deg) **translate(-50%,-50%);** opacity: 0;}

}@-webkit-keyframes span2{

0%{transform: rotate(0deg) **translate(-50%,-50%);** opacity: .5;}50%{transform: rotate(180deg) **translate(-50%,-50%);** opacity: 1;}100%{transform: rotate(360deg) **translate(-50%,-50%);** opacity: .5;}

}

回答5:

原因是樓上說的,因為用了css3動畫,所上面設置偏移的時候不要用transfrom,順手把具體的代碼寫出來:

<!DOCTYPE html><html><head> <meta charset='utf-8'> <title></title> <style type='text/css'>* { padding: 0px; margin: 0px;}.box1 { width: 600px; height: 200px; background: orange; position: relative;}.box1 span { position: absolute; border: 8px solid #fff; border-top: 8px solid transparent; border-radius: 999px; top: 50%; left: 50%; /*移除這里定位*/}.box1 span:nth-child(1) { width: 80px; height: 80px; /*新增*/ margin-left: -40px; margin-top: -40px; animation: span1 2s linear infinite ;}.box1 span:nth-child(2) { width: 40px; height: 40px; /*新增*/ margin-left: -20px; margin-top: -20px; animation: span2 1s linear infinite ;}@keyframes span1 { 0% {transform: rotate(360deg);opacity: 1; } 50% {transform: rotate(180deg);opacity: .5; } 100% {transform: rotate(0deg);opacity: 0; }}@-webkit-keyframes span1 { 0% {transform: rotate(360deg);opacity: 1; } 50% {transform: rotate(180deg);opacity: .5; } 100% {transform: rotate(0deg);opacity: 0; }}@-webkit-keyframes span2 { 0% {transform: rotate(0deg);opacity: .5; } 50% {transform: rotate(180deg);opacity: 1; } 100% {transform: rotate(360deg);opacity: .5; }} </style></head><body> <p class='box1'><span></span><span></span> </p></body></html>回答6:

你需要用絕對定位將要旋轉的元素的初始點定位到元素的中心,正常的初始點是在左上用left:50%;top:50%;margin-left:-20px/元素的二分之一/;margin-top:-20px/元素的二分之一/;這樣元素的旋轉就不會出現交錯了。

標簽: CSS
主站蜘蛛池模板: 免费在线一级毛片 | 亚洲精品国产精品一区二区 | 久艹视频在线 | 国产好片无限资源 | 91资源在线播放 | 韩国a级毛片 | 国产欧美日韩三级 | 免费一级毛片在线播放放视频 | 亚洲免费视频一区 | 免费人成黄页网站在线观看国产 | 亚洲人成片在线观看 | 成人精品一区二区三区 | 中文字幕久久久 | 亚洲欧美一区二区三区在线播放 | 国产精品一区二区综合 | 成人午夜看片在线观看 | 久久久久久久久久久9精品视频 | 亚洲国产一区二区三区四区 | 国产欧美综合一区二区 | 香蕉依依精品视频在线播放 | 亚洲精品福利一区二区三区 | 国产特级全黄一级毛片不卡 | 一级大黄美女免费播放 | 久久久久久免费播放一级毛片 | 久久久精品一区二区三区 | 在线观看免费黄色网址 | 日韩一区二区精品久久高清 | 欧美日韩一区二区综合 | 国产区一区二区三 | 欧美亚洲日本在线 | 免费看一级毛片欧美 | 日本a级三级三级三级久久 日本a级特黄三级三级三级 | 欧美成人tv在线观看免费 | 美女黄网站色一级毛片 | 中文字幕日韩一区二区不卡 | 色老头老太做爰视频在线观看 | 亚洲综合色视频在线观看 | 日韩一级片视频 | 中文字幕亚洲欧美日韩不卡 | 久久精品国产半推半就 | 亚洲免费视频在线观看 |