Vue2.x通用編輯組件的封裝及應(yīng)用詳解
本文實(shí)例為大家分享了Vue2.x通用編輯組件的封裝及應(yīng)用,供大家參考,具體內(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="請(qǐng)輸入新名稱" name="測(cè)試名稱" 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'目的是為了引入編輯圖標(biāo),圖標(biāo)使用于iconfont官網(wǎng)使用svg制作,實(shí)際應(yīng)用時(shí)請(qǐng)刪除此行代碼,改為你自己的圖標(biāo),即給.editLogo加個(gè)背景圖即可。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Vue2與Vue3兄弟組件通訊bus的區(qū)別及用法
- vue2.* element tabs tab-pane 動(dòng)態(tài)加載組件操作
- vue2.0 獲取從http接口中獲取數(shù)據(jù),組件開發(fā),路由配置方式
- vue2.0+SVG實(shí)現(xiàn)音樂播放圓形進(jìn)度條組件
- vue2 拖動(dòng)排序 vuedraggable組件的實(shí)現(xiàn)
- Vue2.x通用條件搜索組件的封裝及應(yīng)用詳解
- Vue2.0實(shí)現(xiàn)組件之間數(shù)據(jù)交互和通信操作示例
- 詳解基于Vue2.0實(shí)現(xiàn)的移動(dòng)端彈窗(Alert, Confirm, Toast)組件
- 在vue2.0中引用element-ui組件庫的方法
- Vue2 的12種組件通訊
相關(guān)文章
基于vue3開發(fā)mobile-table適用于移動(dòng)端表格
這篇文章主要給大家介紹了關(guān)于如何基于vue3開發(fā)mobile-table適用于移動(dòng)端表格的相關(guān)資料,需要的朋友可以參考下2024-03-03Vue前端導(dǎo)出Excel文件的詳細(xì)實(shí)現(xiàn)方案
在開發(fā)后臺(tái)管理系統(tǒng)的時(shí)候,很多地方都要用到導(dǎo)出excel表格,比如將table中的數(shù)據(jù)導(dǎo)出到本地,下面這篇文章主要給大家介紹了關(guān)于Vue導(dǎo)出Excel文件的相關(guān)資料,需要的朋友可以參考下2021-09-09vue刷新頁面時(shí)去閃爍提升用戶體驗(yàn)效果的實(shí)現(xiàn)方法
這篇文章主要介紹了vue刷新頁面時(shí)去閃爍提升體驗(yàn)方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-12-12vue項(xiàng)目部署到Apache服務(wù)器中遇到的問題解決
這篇文章主要介紹了vue項(xiàng)目部署到Apache中遇到的問題解決,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-08-08vue cli3.0結(jié)合echarts3.0與地圖的使用方法示例
這篇文章主要給大家介紹了關(guān)于vue cli3.0結(jié)合echarts3.0與地圖的使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03vue使用css-rcurlyexpected等less報(bào)錯(cuò)問題
這篇文章主要介紹了vue使用css-rcurlyexpected等less報(bào)錯(cuò)問題,具有很的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10