Vue项目结合Vue-layer实现弹框式编辑功能(实例代码)
(编辑:jimmy 日期: 2025/1/7 浏览:3 次 )
1. 实现效果
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>
下一篇:使用Node.js实现base64和png文件相互转换的方法