Vue2.x通用編輯組件的封裝及應用詳解
更新時間:2019年05月28日 11:51:33 作者:ECMAScripter
這篇文章主要為大家詳細介紹了Vue2.x通用編輯組件的封裝及應用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了Vue2.x通用編輯組件的封裝及應用,供大家參考,具體內(nèi)容如下
效果

組件源碼
<template>
<div class="edit-input">
<div class="editBox">
<div>
<span class="list">{{ name }}:</span>
<span class="listValue" v-if="!editStatus">{{value}}</span>
</div>
<span class="editLogo iconfont icon-Edit" @click="editStatus = !editStatus" v-if="!editStatus"></span>
<div class="edit" v-if="editStatus">
<el-input v-model="newValue" :placeholder="placeholderDes"></el-input>
<span class="confirmEdit" @click="changeValue">√</span>
<span class="cancel" @click="editStatus = !editStatus">×</span>
</div>
</div>
</div>
</template>
<script>
import '@/common/font/iconfont.css'
export default {
props: {
name: {
type: String,
require: true
},
value: {
type: String,
require: true
},
placeholderDes: {
type: String,
default: ''
}
},
data () {
return {
newValue: '',
editStatus: false
}
},
methods: {
changeValue () {
this.$emit('valueChange', this.newValue)
this.editStatus = false
}
}
}
</script>
<style lang="less" scoped>
.edit-input {
.editBox {
display: flex;
margin-top: 10px;
text-align: center;
.list {
color: #909399;
font-size: 14px;
line-height: 40px;
display: inline-block;
}
.listValue {
color: #303133;
font-size: 14px;
line-height: 26px;
}
.editLogo {
color: #2695E4;
padding-top: 12px;
padding-left: 10px;
}
.edit{
height: 50px;
width: 260px;
.confirmEdit {
margin-left: 4px;
width: 20px;
height: 36px;
display: inline-block;
color: #67c23a;
font-size: 20px;
cursor: pointer;
}
.cancel {
color: #929398;
font-size: 20px;
margin-left: 6px;
cursor: pointer;
width: 20px;
height: 36px;
display: inline-block;
font-size: 26px;
&:hover {
color: #fa5555;
}
}
.el-input {
width: 200px;
}
}
}
}
</style>
父組件中引用
<template>
<div class="test">
<v-edit-input placeholderDes="請輸入新名稱" name="測試名稱" value="哈哈哈哈" @valueChange="changeValue"></v-edit-input>
</div>
</template>
<script>
import VEditInput from '@/components/Common/EditInput'
export default {
components: {
VEditInput
},
methods: {
changeValue (newVal) {
// newVal即為修改后的新值,接下來用來與后端交互即可。
}
}
}
</script>
注:組件源碼中import '@/common/font/iconfont.css'目的是為了引入編輯圖標,圖標使用于iconfont官網(wǎng)使用svg制作,實際應用時請刪除此行代碼,改為你自己的圖標,即給.editLogo加個背景圖即可。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- Vue2與Vue3兄弟組件通訊bus的區(qū)別及用法
- vue2.* element tabs tab-pane 動態(tài)加載組件操作
- vue2.0 獲取從http接口中獲取數(shù)據(jù),組件開發(fā),路由配置方式
- vue2.0+SVG實現(xiàn)音樂播放圓形進度條組件
- vue2 拖動排序 vuedraggable組件的實現(xiàn)
- Vue2.x通用條件搜索組件的封裝及應用詳解
- Vue2.0實現(xiàn)組件之間數(shù)據(jù)交互和通信操作示例
- 詳解基于Vue2.0實現(xiàn)的移動端彈窗(Alert, Confirm, Toast)組件
- 在vue2.0中引用element-ui組件庫的方法
- Vue2 的12種組件通訊
相關文章
基于vue3開發(fā)mobile-table適用于移動端表格
這篇文章主要給大家介紹了關于如何基于vue3開發(fā)mobile-table適用于移動端表格的相關資料,需要的朋友可以參考下2024-03-03
vue刷新頁面時去閃爍提升用戶體驗效果的實現(xiàn)方法
這篇文章主要介紹了vue刷新頁面時去閃爍提升體驗方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2018-12-12
vue cli3.0結合echarts3.0與地圖的使用方法示例
這篇文章主要給大家介紹了關于vue cli3.0結合echarts3.0與地圖的使用方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用vue具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-03-03
vue使用css-rcurlyexpected等less報錯問題
這篇文章主要介紹了vue使用css-rcurlyexpected等less報錯問題,具有很的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10

