Vue实现新增操作

Vue实现新增操作

新增的逻辑:

  1. 前端页面上,点击新增按钮,对应一个handleadd方法,该方法创建一个空的form对象,并打开一个对话框,对话框里有各种输入框,输入框里通过v-model绑定输入的内容和form对象的各种属性
  2. 在输入框里填写各种字段
  3. 点击“确认”按钮,绑定一个@click的save事件,生成所需的form对象,并将该对象发送至后端
  4. 后端接收到前端传过来的数据,封装成一个input对象。
  5. 在后端的新增方法里面,将input对象的数据提取出来,封装进所对应的实体类对象。
  6. 利用mybatisPlus里的mapper方法,将封装好的实体类对象插入数据库中。
  7. 执行load操作,刷新页面

实现代码

<!-- el-button 按钮 -->
<el-button type="primary" @click="handleadd">新增用户</el-button>


<el-dialog title="用户信息" :visible.sync="dialogFormVisible">
          <el-form label-width="120px">
            <el-form-item label="用户名" >
              <el-input v-model="form.username" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="密码" >
              <el-input v-model="form.password" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="手机号" >
              <el-input v-model="form.phoneNumber" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="姓名" >
              <el-input v-model="form.realname" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="学校" >
              <el-input v-model="form.schoolName" autocomplete="off"></el-input>
            </el-form-item>   
            <el-form-item label="国家" >
              <el-input v-model="form.country" autocomplete="off"></el-input>
            </el-form-item>      
          </el-form>
          <div slot="footer" class="dialog-footer">
            <el-button @click="dialogFormVisible = false">取 消</el-button>
            <el-button type="primary" @click="save">确 定</el-button>
          </div>
        </el-dialog>
 <script>
    method: {
    load(){
        this.request.get("/user/page", {  //这里填的是传进后端的参数
        params: {
          pageNum: this.pageNum,
          pageSize: this.pageSize,
          name: this.username,

        }
      }).then(res => {
        console.log(res)

        this.tableData = res.data.data.records
        this.total = res.data.data.total

      })
      },  
    handleadd(){
        this.dialogFormVisible = true
        this.form = {}
      },
      //新增
      save() {
      this.request.post("/user/adduser", this.form).then(res => {
        if (res.code === '200') {
          this.$message.success("保存成功")
          this.dialogFormVisible = false
          this.load()
        } else {
          this.$message.error("保存失败")
        }
      }
</script>       
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

封心心心心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值