Vue2.x通用編輯組件的封裝及應用詳解
更新時間:2019年05月28日 11:51:33 作者:ECMAScripter
這篇文章主要為大家詳細介紹了Vue2.x通用編輯組件的封裝及應用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了Vue2.x通用編輯組件的封裝及應用,供大家參考,具體內容如下
效果
組件源碼
<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加個背景圖即可。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- 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-03vue刷新頁面時去閃爍提升用戶體驗效果的實現(xiàn)方法
這篇文章主要介紹了vue刷新頁面時去閃爍提升體驗方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2018-12-12vue cli3.0結合echarts3.0與地圖的使用方法示例
這篇文章主要給大家介紹了關于vue cli3.0結合echarts3.0與地圖的使用方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用vue具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-03-03vue使用css-rcurlyexpected等less報錯問題
這篇文章主要介紹了vue使用css-rcurlyexpected等less報錯問題,具有很的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10