62 lines
1.5 KiB
Vue
62 lines
1.5 KiB
Vue
<template>
|
|
<div class="app-container">
|
|
<el-tabs v-model="activeName">
|
|
<el-tab-pane label="use clipboard directly" name="directly">
|
|
<el-input
|
|
v-model="inputData"
|
|
placeholder="Please input"
|
|
:style="inputStyle"
|
|
/>
|
|
<el-button type="primary" icon="el-icon-document" @click="handleCopy(inputData,$event)">
|
|
copy
|
|
</el-button>
|
|
</el-tab-pane>
|
|
<el-tab-pane label="use clipboard by v-directive" name="v-directive">
|
|
<el-input
|
|
v-model="inputData"
|
|
placeholder="Please input"
|
|
:style="inputStyle"
|
|
/>
|
|
<el-button v-clipboard:copy="inputData" v-clipboard:success="clipboardSuccess" type="primary" icon="el-icon-document">
|
|
copy
|
|
</el-button>
|
|
</el-tab-pane>
|
|
</el-tabs>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import clip from '@/utils/clipboard' // use clipboard directly
|
|
import clipboard from '@/directive/clipboard/index.js' // use clipboard by v-directive
|
|
|
|
export default {
|
|
name: 'ClipboardDemo',
|
|
directives: {
|
|
clipboard
|
|
},
|
|
data() {
|
|
return {
|
|
activeName: 'directly',
|
|
inputStyle: {
|
|
maxWidth: '100%',
|
|
width: '400px'
|
|
},
|
|
inputData: 'https://github.com/PanJiaChen/vue-element-admin'
|
|
}
|
|
},
|
|
methods: {
|
|
handleCopy(text, event) {
|
|
clip(text, event)
|
|
},
|
|
clipboardSuccess() {
|
|
this.$message({
|
|
message: 'Copy successfully',
|
|
type: 'success',
|
|
duration: 1500
|
|
})
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|