f57d849bc5cc6dcbd2a7ec448da9a134590dbc42.svn-base 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <template>
  2. <a-modal
  3. title="配置地址"
  4. :visible="onlineUrlVisible"
  5. @cancel="handleOnlineUrlClose">
  6. <template slot="footer">
  7. <a-button @click="handleOnlineUrlClose">关闭</a-button>
  8. <a-button type="primary" class="copy-this-text" :data-clipboard-text="url" @click="onCopyUrl">复制</a-button>
  9. </template>
  10. <template v-if="typeof url === 'string'">
  11. <p>{{ url }}</p>
  12. </template>
  13. <template v-for="(item,i) in url">
  14. <p :key="i"><span>{{item.label}}</span><span>{{ item.url }}</span></p>
  15. </template>
  16. </a-modal>
  17. </template>
  18. <script>
  19. import Clipboard from 'clipboard'
  20. export default {
  21. name: 'ConfigUrlModal',
  22. props: {
  23. url: {
  24. type: [String, Array],
  25. default: () => []
  26. }
  27. },
  28. data() {
  29. return {
  30. onlineUrlVisible: false
  31. }
  32. },
  33. computed: {
  34. },
  35. mounted() {
  36. },
  37. methods: {
  38. onCopyUrl() {
  39. var clipboard = new Clipboard('.copy-this-text')
  40. clipboard.on('success', () => {
  41. clipboard.destroy()
  42. this.$message.success('复制成功')
  43. this.handleOnlineUrlClose()
  44. })
  45. clipboard.on('error', () => {
  46. this.$message.error('该浏览器不支持自动复制')
  47. clipboard.destroy()
  48. })
  49. },
  50. handleOnlineUrlClose() {
  51. this.onlineUrlVisible = false
  52. },
  53. setOnlineUrlVisible(value) {
  54. this.onlineUrlVisible = value
  55. }
  56. }
  57. }
  58. </script>