gpt4 book ai didi

javascript - 如何使用@angular/animations 为 ScrollTop 设置动画?

转载 作者:数据小太阳 更新时间:2023-10-29 03:57:03 24 4
gpt4 key购买 nike

我正在尝试从 Material.io 复制这个动画:

Card Animation

在上面的示例中,只需像点击第一张卡片那样导航高度就很简单。只是动画高度属性。问题在于点击第二张卡片,然后将其他卡片推开。

一个解决方案是使用滚动来模拟事物被推开的效果。因此,当您单击该项目时,它会通过设置高度动画使其变高,同时还会 ScrollView 。

我的问题:我似乎无法弄清楚如何使用 @angular/animations 制作滚动动画。我不能使用 style({ scrollTop: 100 }),它只允许根据 documentation 的 CSS 属性.

我如何实现这一目标?如果出于维护原因(为了将整个动画保持在代码中的 1 个位置),我可以将它作为 animate() 动画的一部分来做,那会很好,但如果只能使用单独的方法我想这也是可以接受的。

最佳答案

我设法创建了这个,使用了三种 Angular 动画状态:smallbignormal,对应于 div 的高度:

animations.ts

在这里,我以每个 div 使用一个状态变量为例,并将这些状态中的每一个默认设置为正常。然后,根据我点击的 div,我根据我们想要发生的事情切换状态:让我们点击的 div 变大,让其他的 变小

export const expand = [
trigger('expand', [
state('big', style({
'height': '200px'
})),
state('normal', style({
'height': '100px'
})),
state('small', style({
'height': '50px'
})),
transition('* => *', [group([
animate(1000)
]
)])
]),
]

app.component.ts

import { expand } from './animations';

@Component({
...
animations: [expand]
})
export class AppComponent implements OnInit {
expandState1 = 'normal';
expandState2 = 'normal';
expandState3 = 'normal';
expandState4 = 'normal';
expandState5 = 'normal';

ngOnInit() {
this.resetStates();
}

resetStates() {
this.expandState1 = 'normal';
this.expandState2 = 'normal';
this.expandState3 = 'normal';
this.expandState4 = 'normal';
this.expandState5 = 'normal';
}

toggleShowDiv(divName: string) {
if (divName === 'div1') {
if (this.expandState1 === 'normal' || this.expandState1 === 'small') {
this.setToBig([1]);
this.setToSmall([2, 3, 4, 5]);
} else if (this.expandState1 === 'big' || this.expandState1 === 'small') {
this.resetStates();
}
} else if (divName === 'div2') {
if (this.expandState2 === 'normal' || this.expandState2 === 'small') {
this.setToBig([2]);
this.setToSmall([1, 3, 4, 5]);
} else if (this.expandState2 === 'big') {
this.resetStates();
}
} else if (divName === 'div3') {
if (this.expandState3 === 'normal' || this.expandState3 === 'small') {
this.setToBig([3]);
this.setToSmall([1, 2, 4, 5]);
} else if (this.expandState3 === 'big') {
this.resetStates();
}
} else if (divName === 'div4') {
if (this.expandState4 === 'normal' || this.expandState4 === 'small') {
this.setToBig([4]);
this.setToSmall([1, 2, 3, 5]);
} else if (this.expandState4 === 'big') {
this.resetStates();
}
} else if (divName === 'div5') {
if (this.expandState5 === 'normal' || this.expandState5 === 'small') {
this.setToBig([5]);
this.setToSmall([1, 2, 3, 4]);
} else if (this.expandState5 === 'big') {
this.resetStates();
}
}
}

setToSmall(choices: any) {
for (let i = 0; i < choices.length; i++) {
switch (choices[i]) {
case 1:
this.expandState1 = 'small';
break;
case 2:
this.expandState2 = 'small';
break;
case 3:
this.expandState3 = 'small';
break;
case 4:
this.expandState4 = 'small';
break;
case 5:
this.expandState5 = 'small';
break;
default:
break;
}
}
}

setToBig(choices: any) {
for (let i = 0; i < choices.length; i++) {
switch (choices[i]) {
case 1:
this.expandState1 = 'big';
break;
case 2:
this.expandState2 = 'big';
break;
case 3:
this.expandState3 = 'big';
break;
case 4:
this.expandState4 = 'big';
break;
case 5:
this.expandState5 = 'big';
break;
default:
break;
}
}
}
}

这是相应的模板:

每个 div 都有对动画触发器 [@expand] 及其状态的引用。

<div class="wrapper scrollableDiv">
<div [@expand]="expandState1" (click)="toggleShowDiv('div1')" class="content divA">THIS IS CONTENT DIV 1</div>
<div [@expand]="expandState2" (click)="toggleShowDiv('div2')" class="content divA">THIS IS CONTENT DIV 2</div>
<div [@expand]="expandState3" (click)="toggleShowDiv('div3')" class="content divA">THIS IS CONTENT DIV 3</div>
<div [@expand]="expandState4" (click)="toggleShowDiv('div4')" class="content divA">THIS IS CONTENT DIV 4</div>
<div [@expand]="expandState5" (click)="toggleShowDiv('div5')" class="content divA">THIS IS CONTENT DIV 5</div>
</div>

这是我为此制作的 StackBlitz 示例:https://stackblitz.com/edit/angular-t47iyy

关于javascript - 如何使用@angular/animations 为 ScrollTop 设置动画?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45992012/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com