Saya tahu ini sudah banyak dipilih di sini sekarang, tetapi saya lebih suka menggunakan pendekatan direktif kustom dan mengandalkan ClipboardEvent seperti yang disarankan @jockeisorby, sambil juga memastikan pendengar dihapus dengan benar (fungsi yang sama perlu disediakan untuk event listener add dan remove)
stackblitz demo
import { Directive, Input, Output, EventEmitter, HostListener } from "@angular/core";
@Directive({ selector: '[copy-clipboard]' })
export class CopyClipboardDirective {
@Input("copy-clipboard")
public payload: string;
@Output("copied")
public copied: EventEmitter<string> = new EventEmitter<string>();
@HostListener("click", ["$event"])
public onClick(event: MouseEvent): void {
event.preventDefault();
if (!this.payload)
return;
let listener = (e: ClipboardEvent) => {
let clipboard = e.clipboardData || window["clipboardData"];
clipboard.setData("text", this.payload.toString());
e.preventDefault();
this.copied.emit(this.payload);
};
document.addEventListener("copy", listener, false)
document.execCommand("copy");
document.removeEventListener("copy", listener, false);
}
}
dan kemudian menggunakannya seperti itu
<a role="button" [copy-clipboard]="'some stuff'" (copied)="notify($event)">
<i class="fa fa-clipboard"></i>
Copy
</a>
public notify(payload: string) {
// Might want to notify the user that something has been pushed to the clipboard
console.info(`'${payload}' has been copied to clipboard`);
}
Catatan: perhatikan yang window["clipboardData"]
diperlukan untuk IE karena tidak mengertie.clipboardData