本文实例为大家分享了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官网使用svg制作,实际应用时请删除此行代码,改为你自己的图标,即给.editLogo加个背景图即可。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Android信息界面编辑及组合控件的封装,包括了Android信息界面编辑及组合控件的封装的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android编辑信息界面,及组合控件的封装,供大家参考,具体内容如下 Github地址(完整Demo,欢迎下载) 效果图 attrs.xml 获取到各属性 xml布局文件 调用的activity 以上就是本文的全部内容,希望对大
本文向大家介绍webpack4.x下babel的安装、配置及使用详解,包括了webpack4.x下babel的安装、配置及使用详解的使用技巧和注意事项,需要的朋友参考一下 前言 目前,ES6(ES2015)这样的语法已经得到很大规模的应用,它具有更加简洁、功能更加强大的特点,实际项目中很可能会使用采用了ES6语法的模块,但浏览器对于ES6语法的支持并不完善。为了实现兼容,就需要使用转换工具对ES6
本文向大家介绍Python eval的常见错误封装及利用原理详解,包括了Python eval的常见错误封装及利用原理详解的使用技巧和注意事项,需要的朋友参考一下 最近在代码评审的过程,发现挺多错误使用eval导致代码注入的问题,比较典型的就是把eval当解析dict使用,有的就是简单的使用eval,有的就是错误的封装了eval,供全产品使用,这引出的问题更严重,这些都是血淋淋的教训,大家使用的时
本文向大家介绍android 中 SQLiteOpenHelper的封装使用详解,包括了android 中 SQLiteOpenHelper的封装使用详解的使用技巧和注意事项,需要的朋友参考一下 在android中常用存储数据的基本就三种,sqlite,SharedPreferences,文件存储,其中针对于对象存储,使用sqlite比较多,因为可以对其进行增删改查。本文主要讲解SQLiteOpe
我一直在研究封装的概念,发现了一些关于这个主题的不错的线索,比如这个和这个。但我还没能找到一个具体问题的答案。我将使用Swift中的一个示例。 假设你有一个RoadTrip类型的对象: 现在让我们假设应用程序将计算,这是唯一的公共属性: 每加仑平均英里数的计算是RoadTrip对象执行和更新其的私有方法,还是可以接受由单独实用程序类中的另一个方法执行计算,然后更新RoadTrip的属性对象是否使用
本文向大家介绍详解vue中axios的使用与封装,包括了详解vue中axios的使用与封装的使用技巧和注意事项,需要的朋友参考一下 分享下我自己的axios封装 axios是个很好用的插件,都是一些params对象,所以很方便做一些统一处理 当然首先是npm安装axios 很简单$ npm install axios --save 在src下新建文件夹 service / index.js 接着上