Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Angular [cdkCopyToClipboard] beeing called repeatedly

I am using the ClipboardModule from @angular/cdk/clipboard to copy data from my angular form, the problem is that i just realized that my CopyDeatils() method is being called continuously but the value is only copied when the button is pressed.

here is my code:

CopyDetails(): string {       
        return "details ...";       
    }

and this is how it is being called:

<button [cdkCopyToClipboard]="CopyDetails()" type="button">Copy</button>

like image 395
charbel Avatar asked Oct 20 '25 16:10

charbel


1 Answers

I assume you're using default change detection. In that case the function will be called multiple times based on refresh cycle. You could instead bind the cdkCopyToClipboard to variable and use either mouseup or click event handler to bind the function. Try the following

Controller

copyToClipboard: string;

CopyDetails(): string {
  ...       
  copyToClipboard = "details ...";       
}

Template

<button 
  (mouseup)="CopyDetails()"
  [cdkCopyToClipboard]="copyToClipboard" 
  type="button"
>Copy</button>

Edit: move (mouseup) event handler before [cdkCopyToClipboard] binding based on OP's comment

like image 72
ruth Avatar answered Oct 23 '25 05:10

ruth