Как перевернуть фоновое изображение с помощью CSS? - PullRequest
206 голосов
/ 24 апреля 2011

Как перевернуть любое фоновое изображение с помощью CSS?Возможно ли это?

в настоящее время я использую это изображение стрелки в background-image из li в css

enter image description here

Вкл .: visited Iнужно перевернуть эту стрелку по горизонтали.Я могу сделать это, чтобы сделать еще одно изображение стрелки НО Мне просто интересно узнать, возможно ли перевернуть изображение в CSS для :visited

Ответы [ 5 ]

216 голосов
/ 24 апреля 2011

Вы можете перевернуть его по горизонтали с помощью CSS ...

a:visited {
    -moz-transform: scaleX(-1);
    -o-transform: scaleX(-1);
    -webkit-transform: scaleX(-1);
    transform: scaleX(-1);
    filter: FlipH;
    -ms-filter: "FlipH";
}

jsFiddle .

Если вы хотите перевернуть по вертикали ...

a:visited {
    -moz-transform: scaleY(-1);
    -o-transform: scaleY(-1);
    -webkit-transform: scaleY(-1);
    transform: scaleY(-1);
    filter: FlipV;
    -ms-filter: "FlipV";
}

Источник .

73 голосов
/ 24 апреля 2011

Я нашел способ перевернуть только фон, а не весь элемент, увидев подсказку, чтобы перевернуть ответ Алекса. Спасибо, Алекс, за твой ответ

HTML

<div class="prev"><a href="">Previous</a></div>
<div class="next"><a href="">Next</a></div>

CSS

.next a, .prev a {
    width:200px;
    background:#fff
}
 .next {
    float:left
}
 .prev {
    float:right
}
 .prev a:before, .next a:before {
    content:"";
    width:16px;
    height:16px;
    margin:0 5px 0 0;
    background:url(http://i.stack.imgur.com/ah0iN.png) no-repeat 0 0;
    display:inline-block 
}
 .next a:before {
    margin:0 0 0 5px;
    transform:scaleX(-1);
}

См. Пример здесь http://jsfiddle.net/qngrf/807/

17 голосов
/ 30 января 2014

По данным w3schools: http://www.w3schools.com/cssref/css3_pr_transform.asp

Свойство transform поддерживается в Internet Explorer 10, Firefox и Opera. Internet Explorer 9 поддерживает альтернативное свойство -ms-transform (только для 2D-преобразований). Safari и Chrome поддерживают альтернативное свойство -webkit-transform (3D и 2D преобразования). Opera поддерживает только 2D-преобразования.

Это двумерное преобразование, поэтому оно должно работать с префиксами поставщика в Chrome, Firefox, Opera, Safari и IE9 +.

Другие ответы, использованные: прежде чем остановить его переворачивание внутреннего содержимого. Я использовал это в моем нижнем колонтитуле (чтобы вертикально отразить изображение из моего заголовка):

HTML:

<footer>
<p><a href="page">Footer Link</a></p>
<p>&copy; 2014 Company</p>
</footer>

CSS:

footer {
background:url(/img/headerbg.png) repeat-x 0 0;

/* flip background vertically */
-webkit-transform:scaleY(-1);
-moz-transform:scaleY(-1);
-ms-transform:scaleY(-1);
-o-transform:scaleY(-1);
transform:scaleY(-1);
}

/* undo the vertical flip for all child elements */
footer * {
-webkit-transform:scaleY(-1);
-moz-transform:scaleY(-1);
-ms-transform:scaleY(-1);
-o-transform:scaleY(-1);
transform:scaleY(-1);
}

Таким образом, вы в конечном итоге переворачиваете элемент, а затем переворачиваете все его дочерние элементы. Работает и с вложенными элементами.

11 голосов
/ 24 апреля 2011

Что бы это ни стоило, для браузеров на базе Gecko вы не можете отрегулировать эту вещь на :visited из-за возникающих утечек конфиденциальности. Смотри http://hacks.mozilla.org/2010/03/privacy-related-changes-coming-to-css-vistited/

5 голосов
/ 20 сентября 2015

Вы можете перевернуть как вертикальное, так и горизонтальное одновременно

    -moz-transform: scaleX(-1) scaleY(-1);
    -o-transform: scaleX(-1) scaleY(-1);
    -webkit-transform: scaleX(-1) scaleY(-1);
    transform: scaleX(-1) scaleY(-1);

А со свойством transition вы можете получить крутой переворот

    -webkit-transition: transform .4s ease-out 0ms;
    -moz-transition: transform .4s ease-out 0ms;
    -o-transition: transform .4s ease-out 0ms;
    transition: transform .4s ease-out 0ms;
    transition-property: transform;
    transition-duration: .4s;
    transition-timing-function: ease-out;
    transition-delay: 0ms;

На самом деле он переворачивает целый элемент, а не только background-image

SNIPPET

function flip(){
	var myDiv = document.getElementById('myDiv');
	if (myDiv.className == 'myFlipedDiv'){
		myDiv.className = '';
	}else{
		myDiv.className = 'myFlipedDiv';
	}
}
#myDiv{
  display:inline-block;
  width:200px;
  height:20px;
  padding:90px;
  background-color:red;
  text-align:center;
  -webkit-transition:transform .4s ease-out 0ms;
  -moz-transition:transform .4s ease-out 0ms;
  -o-transition:transform .4s ease-out 0ms;
  transition:transform .4s ease-out 0ms;
  transition-property:transform;
  transition-duration:.4s;
  transition-timing-function:ease-out;
  transition-delay:0ms;
}
.myFlipedDiv{
  -moz-transform:scaleX(-1) scaleY(-1);
  -o-transform:scaleX(-1) scaleY(-1);
  -webkit-transform:scaleX(-1) scaleY(-1);
  transform:scaleX(-1) scaleY(-1);
}
<div id="myDiv">Some content here</div>

<button onclick="flip()">Click to flip</button>
...