clipboard.vue 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. <template>
  2. <div class="">
  3. <div v-if="hasClipboard" class="">
  4. <div class="">window.navigator.clipboard</div>
  5. <v-btn @click="writeText()">写入剪贴板</v-btn>
  6. <v-btn @click="readText()">读取剪贴板</v-btn>
  7. </div>
  8. <div v-else class="">
  9. <span>当前环境不支持 window.navigator.clipboard</span>
  10. </div>
  11. </div>
  12. </template>
  13. <script>
  14. export default {
  15. auth: false,
  16. data() {
  17. return {
  18. hasClipboard: false,
  19. };
  20. },
  21. mounted() {
  22. this.hasClipboard = !!window.navigator.clipboard;
  23. },
  24. methods: {
  25. async writeText() {
  26. try {
  27. const now = Date.now();
  28. await navigator.clipboard.writeText(now);
  29. this.$toast.success(`写入成功 ${now}`);
  30. } catch (error) {
  31. this.$toast.error(`写入失败 ${error.message}`);
  32. }
  33. },
  34. async readText() {
  35. try {
  36. const clipText = await navigator.clipboard.readText();
  37. this.$toast.success(`读取成功 ${clipText}`);
  38. } catch (error) {
  39. this.$toast.error(`读取失败 ${error.message}`);
  40. }
  41. },
  42. },
  43. };
  44. </script>