javascript – Angular – 粘贴事件获取内容

我有一个角度组件,允许用户将数据输入textarea.这个keydown和paste有两个事件.这两个事件都会触发相同的方法,该方法将尝试确定输入的数据.

我遇到的问题是粘贴数据时,我得到了formControl的值,但是它的值是在粘贴数据之前的值,而不包括我实际输入到字段中的值.

HTML

<textarea 
  formControlName="multiSearch" 
  class="form-control" 
  placeholder="Enter one or more values. One per line." 
  rows="6" 
  (keydown)="keyDownFunction($event)"
  (paste)="onPaste()">
</textarea>

零件

  /**
   * If we hit enter in our text area, determine the data type
   */
  keyDownFunction(event) {

    // Enter Key?
    if (event.keyCode == 13) {
      this.determineDataType();
    }
  }

  /**
   * If we paste data in our text area, determine the data type
   */
  onPaste() {
    this.determineDataType();
  }

  /**
   * Using regex, determine the datatype of the data and confirm with the user.
   */
  determineDataType() {
    console.log(this.searchForm.value.multiSearch)
  }


如何在粘贴事件被触发后立即访问粘贴到表单中的数据,而不是粘贴之前的值?

解决方法:

您可以通过处理输入事件从粘贴事件和textarea的更新内容中获取粘贴的内容:

<textarea #myText (paste)="onPaste($event)" (input)="onInput(myText.value)"></textarea>

使用此代码:

onPaste(event: ClipboardEvent) {
  let clipboardData = event.clipboardData || window.clipboardData;
  let pastedText = clipboardData.getData('text');
  ...
}

onInput(content: string) {
  ...
}

有关演示,请参见this stackblitz.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐