मेरे पास एक साधारण बहु-कॉलम लेआउट है; मैं पर translateY
का उपयोग कर एक तत्व उठाने की कोशिश कर रहा हूं।मेरा परिवर्तन क्यों करता है: क्रोम में अनुवादित झिलमिलाहट?
यह झिलमिलाहट (क्रोम 57 पर परीक्षण) का कारण बनता है। मैं यह कैसे तय करुं?
"use strict";
$(function() {
var $target = $('.wall');
function getImageUrl(id) {
var width = 500;
var height = 250 + Math.floor(Math.random() * 150);
return "https://unsplash.it/" + width + "/" + height + "?image=" + id;
}
function addElement(element) {
var $template = $target.find('.template').clone().appendTo($target).removeClass("template");
$template.find("a").attr("href", element.post_url);
$template.find("img").attr("src", getImageUrl(element.id));
$template.find("figcaption").text(element.author);
$template.removeClass("hide");
}
$.getJSON("https://unsplash.it/list", function (data) {
var images = 12;
var elements = [];
function getRandomImage() {
var id = Math.floor(Math.random() * data.length);
return data.splice(id, 1)[0];
}
while (images > elements.length) {if (window.CP.shouldStopExecution(1)){break;}
elements.push(getRandomImage());
}
window.CP.exitedLoop(1);
elements.forEach(function (element) {
addElement(element);
});
});
});
.wall {
-webkit-column-count: 3;
-moz-column-count: 3;
column-count: 3;
padding-top: 0.5rem;
}
.wall * {
-webkit-column-break-inside: avoid;
page-break-inside: avoid;
break-inside: avoid;
}
.wall .brick {
display: block;
padding-bottom: 1rem;
}
.wall .brick a {
display: inline-block;
color: inherit;
-webkit-transition: -webkit-transform 333ms ease;
transition: -webkit-transform 333ms ease;
transition: transform 333ms ease;
transition: transform 333ms ease, -webkit-transform 333ms ease;
}
.wall .brick a:hover, .wall .brick a:focus {
-webkit-transform: translateY(-1rem);
transform: translateY(-1rem);
}
.wall .brick .thumbnail {
margin-bottom: 0.5rem;
}
.wall .brick figcaption {
text-align: center;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<div class="wall column">
<div class="hide brick template">
<a>
<figure>
<img class="thumbnail" /><figcaption></figcaption>
</figure>
</a>
</div>
</div>
यह ध्यान रखना दिलचस्प हो सकता है कि मेरे लिए (सफारी 10.1) शीर्ष पंक्ति झिलमिलाहट की केवल मध्यम और सही तस्वीर, अन्य छवियां इरादे के अनुसार आगे और आगे बढ़ती हैं। – 11684
चूंकि क्रोम भी वेबकिट है, यह आपकी समस्या का समाधान कर सकता है: http://stackoverflow.com/questions/2946748/iphone-webkit-css-animations-cause-flicker – 11684
[यह] (http://stackoverflow.com/questions/15751012/सीएसएस-ट्रांसफॉर्म-कारण-झिलमिलाहट-इन-सफारी-लेकिन-केवल-जब-ब्राउज़र-है-2000 पीएक्स-डब्ल्यू) भी समान है। क्या आपने [इन Google परिणामों] को देखा [https://www.google.nl/#q=css+transform+flicker) अभी तक? कई लागू प्रतीत होते हैं। – 11684