12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- <template>
- <div class="editable-cell">
- <div v-if="editable" class="editable-cell-input-wrapper">
- <a-input :value="value" @change="handleChange" @pressEnter="check" /><a-icon
- type="check"
- class="editable-cell-icon-check"
- @click="check"
- />
- </div>
- <div v-else class="editable-cell-text-wrapper">
- {{ value || ' ' }}
- <a-icon type="edit" class="editable-cell-icon" @click="edit" />
- </div>
- </div>
- </template>
- <script>
- export default {
- name: 'EditableCell',
- props: {
- text: {
- type: String,
- default: ''
- }
- },
- data () {
- return {
- value: this.text,
- editable: false
- }
- },
- methods: {
- handleChange (e) {
- this.value = e.target.value
- },
- check () {
- this.editable = false
- this.$emit('change', this.value)
- },
- edit () {
- console.log(1111, this.text)
- this.editable = true
- }
- }
- }
- </script>
- <style>
- .editable-cell {
- position: relative;
- }
- .editable-cell-input-wrapper,
- .editable-cell-text-wrapper {
- padding-right: 24px;
- }
- .editable-cell-text-wrapper {
- padding: 5px 24px 5px 5px;
- }
- .editable-cell-icon,
- .editable-cell-icon-check {
- position: absolute;
- right: 0;
- width: 20px;
- cursor: pointer;
- }
- .editable-cell-icon {
- line-height: 18px;
- display: none;
- }
- .editable-cell-icon-check {
- line-height: 28px;
- }
- .editable-cell:hover .editable-cell-icon {
- display: inline-block;
- }
- .editable-cell-icon:hover,
- .editable-cell-icon-check:hover {
- color: #108ee9;
- }
- .editable-add-btn {
- margin-bottom: 8px;
- }
- </style>
|