How can I programmatically trigger ripple effect on Angular MatListItem?

后端 未结 2 1463
囚心锁ツ
囚心锁ツ 2021-01-21 14:21

In Angular material you have the lovely ripple effect on a lot of the components. When you click on a mat-list-item the ripple effect happens.

Now with buttons and many

相关标签:
2条回答
  • 2021-01-21 14:50

    As of recent versions of Material, there is now a Ripples module (docs here) that allow for the customization and programmatic triggering of ripples in a component, such as mat-list-item.

    Programmatic triggering involves the following: First, we make our list and attach the matRipple directive. In my example, I'm using a button click to trigger the ripple, so an event handler has been added as well:

    <mat-list role="list" matRipple>
      <mat-list-item role="listitem">Item 1</mat-list-item>
      <mat-list-item role="listitem">Item 2</mat-list-item>
      <mat-list-item role="listitem">Item 3</mat-list-item>
    </mat-list>
    <button mat-raised-button color="accent" (click)="triggerRipple()">Trigger Ripple</button>
    

    Within the component, we grab the matRipple using ViewChild, allowing us to call launch() on the ripple to trigger the actual ripple effect:

    @ViewChild(MatRipple) ripple: MatRipple;
    
    triggerRipple() {
      this.ripple.launch({centered: true});
    }
    

    Here's a stackblitz showing this sample in action; click the button to cause a ripple in the mat-list. Naturally, you can move the matRipple directive to any component if you'd like the ripple effect applied to something else. Take a look at the docs for more configuration options available.

    0 讨论(0)
  • 2021-01-21 15:06

    You can try dynamic template reference variable. It works to me.

    import { MatRipple } from '@angular/material/core';
    
    export class FooComponent {
        @ViewChildren(MatRipple) rippleList: QueryList<MatRipple>;
    
        ngAfterViewInit() {
            let ripples = this.rippleList.toArray()
            ripples.forEach(res => {
                    // res is the instance of each matRipple
            })
        }
    
    }
    
    
    

    But It confused to me that I can use it perfect in my project but I can't reappear it in stackblitz:(

    0 讨论(0)
提交回复
热议问题