路径元素上的 GreenSock TimelineMax 在 Safari 和 Firefox 中不起作用
GreenSock TimelineMax on path elements not working in Safari and Firefox
我正在尝试为我在 JavaScript/jQuery 中创建和附加的几个路径元素制作动画。然后我使用时间轴将这些元素一个一个地动画化(具有不同的值,所以我不能使用交错)。最后我不想播放完整的时间线,只想播放其中的一部分。
这在 Chrome 中工作得很好,但在 Safari 和 Firefox 中却不行,我不明白为什么。
这是一个CodePen:
http://codepen.io/elisabeth_hamel/pen/kXqOmw
编辑:
CodePen 已更新,现在可以使用了。
这是代码:
HTML
<svg xmlns='http://www.w3.org/2000/svg' width='20' height='10' viewBox='0 0 2 1' preserveAspectRatio='xMinYMid meet'></svg>
CSS
svg{
width: 100%;
position: absolute;
top: 0;
bottom: 0;
left: 60px;
margin: auto;
overflow: visible;
z-index: 1;
.up{
-webkit-transform: translate3d(0, 40px, 0);
transform: translate3d(0, 40px, 0);
}
.down{
-webkit-transform: translate3d(0, 40px, 0);
transform: translate3d(0, -40px, 0);
}
}
JS
$(function(){
var trianglesTimeline = new TimelineMax({paused: true, smoothChildTiming: true});
function setAnimations(){
var nbTriangles, i = 0, svg = '', random = 1, thisPath;
nbTriangles = ($(window).width() - 60)/9 | 0;
for(i; i<nbTriangles; i++){
random = (Math.random()*(2.5-0.5) + 0.5).toFixed(1);
if(i%2 === 0){
svg += "<path fill='#000' d='M0 0H2 L1 1Z' class='down' data-op='"+random+"' data-x='"+i+"' style='opacity:0'/>";
}else{
svg += "<path fill='#000' d='M0 1H2 L1 0Z' class='up' data-op='"+random+"' data-x='"+i+"' style='opacity:0'/>";
}
}
$('svg').html(svg);
i = 0;
for(i; i<nbTriangles; i++){
thisPath = $('path').eq(i);
TweenMax.set(thisPath, {x: thisPath.data('x')}, 0);
trianglesTimeline.to(thisPath, 0.3, {opacity: thisPath.data('op'), y: '0px', delay: 0.04*i}, 0);
}
trianglesTimeline.tweenTo( trianglesTimeline.duration() * 0.1 );
}
setAnimations();
});
如有任何帮助,我们将不胜感激!
好的,原来 CSS 规则转换规则覆盖了 TweenMax 在路径元素上设置的转换。我不知道为什么!
所以我用内联转换替换了 类。如果有人感兴趣,这是新的工作代码:
CSS
svg{
width: 100%;
position: absolute;
top: 0;
bottom: 0;
left: 60px;
margin: auto;
overflow: visible;
z-index: 1;
}
JS
$(function(){
var trianglesTimeline = new TimelineMax({paused: true, smoothChildTiming: true});
function setAnimations(){
var nbTriangles, i = 0, svg = '', random = 1, thisPath;
nbTriangles = ($(window).width() - 60)/9 | 0;
for(i; i<nbTriangles; i++){
random = (Math.random()*(2.5-0.5) + 0.5).toFixed(1);
if(i%2 === 0){
svg += "<path fill='#000' d='M0 0H2 L1 1Z' transform='translate("+i+", 40)' data-op='"+random+"' style='opacity:0'/>";
}else{
svg += "<path fill='#000' d='M0 1H2 L1 0Z' transform='translate("+i+", -40)' data-op='"+random+"' style='opacity:0'/>";
}
}
$('svg').html(svg);
i = 0;
for(i; i<nbTriangles; i++){
thisPath = $('path').eq(i);
trianglesTimeline.to(thisPath, 0.3, {opacity: thisPath.data('op'), y: '0px', delay: 0.04*i}, 0);
}
trianglesTimeline.tweenTo( trianglesTimeline.duration() * 0.1 );
}
setAnimations();
});
编辑
为了让它在 IE 中工作,我做了一些其他的修改:
$(function(){
function makeSVG(tag, attrs){
var el = document.createElementNS('http://www.w3.org/2000/svg', tag), k;
for(k in attrs){
el.setAttribute(k, attrs[k]);
}
return el;
}
var trianglesTimeline = new TimelineMax({paused: true, smoothChildTiming: true});
function setAnimations(){
var nbTriangles, i = 0, svg = '', random = 1, thisPath, y, d;
nbTriangles = ($(window).width() - 60)/9 | 0;
for(i; i<nbTriangles; i++){
random = (Math.random()*(2.5-0.5) + 0.5).toFixed(1);
if(i%2 === 0){
y = 40;
d = 'M0 0H2 L1 1Z';
}else{
y = -40;
d = 'M0 1H2 L1 0Z';
}
svg = makeSVG('path', {fill: '#000', d: d, transform:'translate('+i+', '+y+')', 'data-op': random, style: 'opacity:0'});
$('svg').append(svg);
}
i = 0;
for(i; i<nbTriangles; i++){
thisPath = $('path').eq(i);
trianglesTimeline.to(thisPath, 0.3, {opacity: thisPath.data('op'), y: '0px', delay: 0.04*i}, 0);
}
trianglesTimeline.tweenTo( trianglesTimeline.duration() * 0.1 );
}
setAnimations();
});
我正在尝试为我在 JavaScript/jQuery 中创建和附加的几个路径元素制作动画。然后我使用时间轴将这些元素一个一个地动画化(具有不同的值,所以我不能使用交错)。最后我不想播放完整的时间线,只想播放其中的一部分。
这在 Chrome 中工作得很好,但在 Safari 和 Firefox 中却不行,我不明白为什么。
这是一个CodePen: http://codepen.io/elisabeth_hamel/pen/kXqOmw
编辑: CodePen 已更新,现在可以使用了。
这是代码:
HTML
<svg xmlns='http://www.w3.org/2000/svg' width='20' height='10' viewBox='0 0 2 1' preserveAspectRatio='xMinYMid meet'></svg>
CSS
svg{
width: 100%;
position: absolute;
top: 0;
bottom: 0;
left: 60px;
margin: auto;
overflow: visible;
z-index: 1;
.up{
-webkit-transform: translate3d(0, 40px, 0);
transform: translate3d(0, 40px, 0);
}
.down{
-webkit-transform: translate3d(0, 40px, 0);
transform: translate3d(0, -40px, 0);
}
}
JS
$(function(){
var trianglesTimeline = new TimelineMax({paused: true, smoothChildTiming: true});
function setAnimations(){
var nbTriangles, i = 0, svg = '', random = 1, thisPath;
nbTriangles = ($(window).width() - 60)/9 | 0;
for(i; i<nbTriangles; i++){
random = (Math.random()*(2.5-0.5) + 0.5).toFixed(1);
if(i%2 === 0){
svg += "<path fill='#000' d='M0 0H2 L1 1Z' class='down' data-op='"+random+"' data-x='"+i+"' style='opacity:0'/>";
}else{
svg += "<path fill='#000' d='M0 1H2 L1 0Z' class='up' data-op='"+random+"' data-x='"+i+"' style='opacity:0'/>";
}
}
$('svg').html(svg);
i = 0;
for(i; i<nbTriangles; i++){
thisPath = $('path').eq(i);
TweenMax.set(thisPath, {x: thisPath.data('x')}, 0);
trianglesTimeline.to(thisPath, 0.3, {opacity: thisPath.data('op'), y: '0px', delay: 0.04*i}, 0);
}
trianglesTimeline.tweenTo( trianglesTimeline.duration() * 0.1 );
}
setAnimations();
});
如有任何帮助,我们将不胜感激!
好的,原来 CSS 规则转换规则覆盖了 TweenMax 在路径元素上设置的转换。我不知道为什么!
所以我用内联转换替换了 类。如果有人感兴趣,这是新的工作代码:
CSS
svg{
width: 100%;
position: absolute;
top: 0;
bottom: 0;
left: 60px;
margin: auto;
overflow: visible;
z-index: 1;
}
JS
$(function(){
var trianglesTimeline = new TimelineMax({paused: true, smoothChildTiming: true});
function setAnimations(){
var nbTriangles, i = 0, svg = '', random = 1, thisPath;
nbTriangles = ($(window).width() - 60)/9 | 0;
for(i; i<nbTriangles; i++){
random = (Math.random()*(2.5-0.5) + 0.5).toFixed(1);
if(i%2 === 0){
svg += "<path fill='#000' d='M0 0H2 L1 1Z' transform='translate("+i+", 40)' data-op='"+random+"' style='opacity:0'/>";
}else{
svg += "<path fill='#000' d='M0 1H2 L1 0Z' transform='translate("+i+", -40)' data-op='"+random+"' style='opacity:0'/>";
}
}
$('svg').html(svg);
i = 0;
for(i; i<nbTriangles; i++){
thisPath = $('path').eq(i);
trianglesTimeline.to(thisPath, 0.3, {opacity: thisPath.data('op'), y: '0px', delay: 0.04*i}, 0);
}
trianglesTimeline.tweenTo( trianglesTimeline.duration() * 0.1 );
}
setAnimations();
});
编辑
为了让它在 IE 中工作,我做了一些其他的修改:
$(function(){
function makeSVG(tag, attrs){
var el = document.createElementNS('http://www.w3.org/2000/svg', tag), k;
for(k in attrs){
el.setAttribute(k, attrs[k]);
}
return el;
}
var trianglesTimeline = new TimelineMax({paused: true, smoothChildTiming: true});
function setAnimations(){
var nbTriangles, i = 0, svg = '', random = 1, thisPath, y, d;
nbTriangles = ($(window).width() - 60)/9 | 0;
for(i; i<nbTriangles; i++){
random = (Math.random()*(2.5-0.5) + 0.5).toFixed(1);
if(i%2 === 0){
y = 40;
d = 'M0 0H2 L1 1Z';
}else{
y = -40;
d = 'M0 1H2 L1 0Z';
}
svg = makeSVG('path', {fill: '#000', d: d, transform:'translate('+i+', '+y+')', 'data-op': random, style: 'opacity:0'});
$('svg').append(svg);
}
i = 0;
for(i; i<nbTriangles; i++){
thisPath = $('path').eq(i);
trianglesTimeline.to(thisPath, 0.3, {opacity: thisPath.data('op'), y: '0px', delay: 0.04*i}, 0);
}
trianglesTimeline.tweenTo( trianglesTimeline.duration() * 0.1 );
}
setAnimations();
});