Vue项目结合Vue-layer实现弹框式编辑功能(实例代码)


Posted in Javascript onMarch 11, 2020

1. 实现效果

Vue项目结合Vue-layer实现弹框式编辑功能(实例代码)

2.实现原理

在父组件中点击编辑按钮,将当前点击对象的id传给子组件,子组件根据id修改相应的内容

父组件中代码:

//放置编辑按钮的位置
<button type="button" class="layui-btn layui-btn-normal layui-btn-sm" v-on:click="edit(manage.id)"><i class="layui-icon"></i>编辑</button>
// 在methods中设计edit()方法
//需要先引入编辑组件
import EditManage from './EditManage'
 edit(id){
    this.$layer.iframe({
     type:2,
     title:"编辑",
     area:['600px','450px'],
     shade:true,
     offset:'auto',
     content:{
      content:EditManage,//传递的编辑组件主线
      parent:this,
      data:{
       info:{id:id}// 传递的要编辑内容的id值
      }
     }
    })
   },

子组件EditManage代码

<template>
 <div class="editmanage container">
  <form class="form" v-on:submit="editManage">
   <div class="form-group">
    <label>账号</label>
    <input type="text" required placeholder="账号" autocomplete="off" class="form-control" v-model="manage.account">
   </div>
   <div class="form-group">
    <label>用户名</label>
    <input type="text" required placeholder="用户名" autocomplete="off" class="form-control" v-model="manage.username">
   </div>
   <div class="form-group">
    <label >密码</label>
    <input type="password" required placeholder="密码" autocomplete="off" class="form-control" v-model="manage.password">
   </div>

   <div class="form-group">
    <label >权限</label>
    <select name="authority" class="form-control" v-model="manage.authority">
     <option value="超级管理员" >超级管理员</option>
     <option value="普通管理员" >普通管理员</option>
    </select>
   </div>
   <button type="submit" class="btn btn-info">立即提交</button>
  </form>
 </div>
</template>

<script>
 export default {
  name: 'addmanage',
  data () {
   return {
    manage:{},
    form:{}
   }
  },
  props:{
  //接收父组件传来的id值
   info:{
    type:Object,
    default:()=>{
     return {}
    }
   },
   layerid:{
    type:String,
    default:""
   },
   lydata:{
    type:Object,
    default:()=>{
     return {}
    }
   }
  },
  methods:{
  //用来显示对应id的编辑内容,在created中调用
   fetchManage(id){
    this.$http.get('http://localhost:3000/manage/'+id)
     .then(function (response) {
      this.manage=response.body;
     })
   },
   editManage(e){
    if(!this.manage.account||!this.manage.username||!this.manage.password||!this.manage.authority){
     this.$layer.msg("请添加对应信息!")
    }else{
     let updateManage={
      account:this.manage.account,
      username:this.manage.username,
      password:this.manage.password,
      authority:this.manage.authority
     };   this.$http.put("http://localhost:3000/manage/"+this.info.id,updateManage)
      .then(function (response) {
      //关闭父组件中的编辑弹框
       this.$layer.close(this.layerid);
       //弹出提示信息,默认时间为3秒
       this.$layer.msg("修改管理员信息成功!");


      });
     e.preventDefault()
    }
    e.preventDefault()
   }
  },
  created(){
  // this.info.id父组件传给子组件的id值
   this.fetchManage(this.info.id);

  }
 }
</script>

<style scoped>
 .editmanage{
  margin:8px 20px 20px 20px;
 }
</style>

到此这篇关于Vue项目结合Vue-layer实现弹框式编辑功能(实例代码)的文章就介绍到这了,更多相关Vue弹框式编辑内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
IE DOM实现存在的部分问题及解决方法
Jul 25 Javascript
Javascript将string类型转换int类型
Dec 09 Javascript
JavaScript实现的日期控件具体代码
Nov 18 Javascript
IE6下javasc#ipt:void(0) 无效的解决方法
Dec 23 Javascript
jQuery中:image选择器用法实例
Jan 03 Javascript
js根据鼠标移动速度背景图片自动旋转的方法
Feb 28 Javascript
JS遍历页面所有对象属性及实现方法
Aug 01 Javascript
JS简单生成两个数字之间随机数的方法
Aug 03 Javascript
微信小程序实战之轮播图(3)
Apr 17 Javascript
node.js 中间件express-session使用详解
May 20 Javascript
jquery.uploadView 实现图片预览上传功能
Aug 10 jQuery
100行代码实现vue表单校验功能(小白自编)
Nov 19 Javascript
使用Node.js实现base64和png文件相互转换的方法
Mar 11 #Javascript
vue 移动端记录页面浏览位置的方法
Mar 11 #Javascript
Js逆向实现滑动验证码图片还原的示例代码
Mar 10 #Javascript
微信小程序获取公众号文章列表及显示文章的示例代码
Mar 10 #Javascript
jquery实现烟花效果(面向对象)
Mar 10 #jQuery
非常漂亮的js烟花效果
Mar 10 #Javascript
微信小程序搜索框样式并实现跳转到搜索页面(小程序搜索功能)
Mar 10 #Javascript
You might like
对盗链说再见...
2006/10/09 PHP
解析posix与perl标准的正则表达式区别
2013/06/17 PHP
php使用exec shell命令注入的方法讲解
2013/11/12 PHP
Linux环境下php实现给网站截图的方法
2016/05/03 PHP
PHP实现的字符串匹配算法示例【sunday算法】
2017/12/19 PHP
javascript 尚未实现错误解决办法
2008/11/27 Javascript
js no-repeat写法 背景不重复
2009/03/18 Javascript
jQuery 自定义函数写法分享
2012/03/30 Javascript
仿谷歌主页js动画效果实现代码
2013/07/14 Javascript
js中继承的几种用法总结(apply,call,prototype)
2013/12/26 Javascript
用JQuery实现全选与取消的两种简单方法
2014/02/22 Javascript
jQuery聚合函数实例
2015/05/21 Javascript
jQuery对JSON数据进行排序输出的方法
2015/06/24 Javascript
js 发布订阅模式的实例讲解
2017/09/10 Javascript
Nginx 配置多站点vhost 的方法
2018/01/07 Javascript
vue加载自定义的js文件方法
2018/03/13 Javascript
移动端图片上传旋转、压缩问题的方法
2018/10/16 Javascript
详解javascript replace高级用法
2019/02/17 Javascript
vue实现简单的日历效果
2020/09/24 Javascript
Vue.js 中的实用工具方法【推荐】
2019/07/04 Javascript
vue动态绘制四分之三圆环图效果
2019/09/03 Javascript
利用d3.js制作连线动画图与编辑器的方法实例
2019/09/05 Javascript
微信小程序错误this.setData报错及解决过程
2019/09/18 Javascript
Node.js API详解之 dns模块用法实例分析
2020/05/15 Javascript
利用Python脚本在Nginx和uwsgi上部署MoinMoin的教程
2015/05/05 Python
怎么使用pipenv管理你的python项目
2018/03/12 Python
详解python项目实战:模拟登陆CSDN
2019/04/04 Python
Pyspark获取并处理RDD数据代码实例
2020/03/27 Python
HTML5新增元素如何兼容旧浏览器有哪些方法
2014/05/09 HTML / CSS
瑞典轮胎在线:Tirendo.se
2018/06/21 全球购物
女子锻炼服装和瑜伽服装:Splits59
2019/03/04 全球购物
波兰家居饰品和厨房配件网上商店:Maleomi
2020/12/15 全球购物
销售文员岗位职责
2013/11/29 职场文书
劳资人员岗位职责
2013/12/19 职场文书
《英英学古诗》教学反思
2014/04/11 职场文书
群教个人对照检查材料
2014/08/20 职场文书