专栏首页前端vue对数据进行一些基本操作(四)

对数据进行一些基本操作(四)

接收post请求(vue+axios)解决跨域问题(三)

效果预览

最终效果预览

node路由配置增删改查
//查询语句
var selAll='select * from list';
//根据post的id查询
var selId='select * from list where id=?';
//插入数据
var addData='insert into list (u_name,u_phone) values (?,?)';
//删除数据
var delData='delete from list where id=?';
//更新数据
var upData='update list set u_name=?,u_phone=? where id=?'
//更新数据
router.post('/edit',function(req,res,next){
    var params=req.body;
    console.log(params)
    pool.getConnection(function(err,suc){
        suc.query(upData,[params.name,params.phone,params.id],function(err,result){
            console.log(err)
            console.log(result)
            if(result){
                result={
                    code:200,
                    msg:'更新数据成功'
                }
            }
            res.json(result);
            suc.release()
        })
    })
})
//删除数据
router.post('/del',function(req,res,next){
    var params=req.body;
    console.log(params)
    pool.getConnection(function(err,suc){
        suc.query(delData,[params.id],function(err,result){
            if(result){
                result={
                    code:200,
                    msg:'删除数据成功'
                }
            }
            res.json(result);
            suc.release()
        })
    })
})
//插入数据
router.post('/add', function(req, res, next) {
    var params=req.body;
    console.log(params)
    pool.getConnection(function(err,suc){
        suc.query(addData,[params.name,params.phone],function(err,result){
            if(result){ //数据库有返回数据
                result={    //返回数据与格式
                    code:200,
                    msg:'新增数据成功'
                }
            }
            res.json(result);   //响应返回json数据
            suc.release();  //关闭数据库连接
        })
    })
});

router.get('/list', function(req, res, next) {
    pool.getConnection(function(err,suc){
        suc.query(selAll,[],function(err,result){
            if(result){ //数据库有返回数据
                result={    //返回数据与格式
                    code:200,
                    msg:'获取测试列表成功',
                    data:result
                }
            }
            res.json(result);   //响应返回json数据
            suc.release();  //关闭数据库连接
        })
    })
});

//响应post
router.post('/list', function(req, res, next) {
    var id=req.body.id; //通过req的body拿到post的id
    pool.getConnection(function(err,suc){
        suc.query(selId,[id],function(err,result){
            if(result){ //数据库有返回数据
                result={    //返回数据与格式
                    code:200,
                    msg:'获取单个测试列表成功',
                    data:result
                }
            }
            res.json(result);   //响应返回json数据
            suc.release();  //关闭数据库连接
        })
    })
});
Vue代码更新

html

<template>
  <div class="hello">
    <ul>
      <li>
        <el-input placeholder="请输入姓名" v-model="name">
          <template slot="prepend">姓名:</template>
        </el-input>
      </li>
      <li>
        <el-input placeholder="请输入电话" v-model="phone">
          <template slot="prepend">电话:</template>
        </el-input>
      </li>
      <li>
        <el-button type="primary" plain @click="add">添加</el-button>
      </li>
    </ul>
    <el-table class="user_table"
      :data="userList"
      border>
      <el-table-column
        fixed
        prop="Id"
        label="用户ID">
      </el-table-column>
      <el-table-column
        prop="u_name"
        label="姓名">
      </el-table-column>
      <el-table-column
        prop="u_phone"
        label="电话">
      </el-table-column>
      <el-table-column
        label="操作">
        <template slot-scope="scope">
          <el-button @click="del(scope.row)" type="text" size="small">删除</el-button>
          <el-button @click="edit(scope)" type="text" size="small">编辑</el-button>
        </template>
      </el-table-column>
    </el-table>
    <el-dialog
      title="编辑"
      :visible.sync="dialogVisible">
      <div class="update">
        <el-input placeholder="请输入姓名" v-model="edit_name">
          <template slot="prepend">姓名:</template>
        </el-input>
        <el-input placeholder="请输入电话" v-model="edit_phone">
          <template slot="prepend">电话:</template>
        </el-input>
      </div>
      <span slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible = false">取 消</el-button>
        <el-button type="primary" @click="editY()">确 定</el-button>
      </span>
    </el-dialog>
  </div>
</template>

script

import axios from 'axios';
export default {
  name: 'HelloWorld',
  data () {
    return {
      // msg: 'Welcome to Your Vue.js App'
      name:'',
      phone:'',
      userList:[],
      dialogVisible:false,
      edit_name:'',
      edit_phone:'',
      edit_id:''
    }
  },
  mounted(){
    this.get()
  },
  methods:{
    editY(){
      var this_=this;
      axios.post('/users/edit',{
        id:this.edit_id,
        name:this.edit_name,
        phone:this.edit_phone
      }).then(function(res){
        console.log(res)
        this_.dialogVisible=false;
        this_.get()
      }).catch(function(err){
        console.log(err)
      })
    },
    edit(row){
      var this_=this,index=row.$index;
      this_.dialogVisible=true;
      var p_id=this_.userList[index].Id,
          p_name=this_.userList[index].u_name,
          p_phone=this_.userList[index].u_phone;
      this_.edit_id=p_id;
      this_.edit_name=p_name;
      this_.edit_phone=p_phone;
    },
    get(){
      var this_=this;
      axios.get('/users/list').then(function(res){
        this_.userList=res.data.data

      }).catch(function(err){
        console.log(err)
      })
    },
    add(){
      var this_=this;
      // var name=,phone=;
      axios.post('/users/add',{
        name:this.name,
        phone:this.phone
      }).then(function(res){
        console.log(res)
        this_.get()
      }).catch(function(err){
        console.log(err)
      })
    },
    del(row){
      var this_=this;
      axios.post('/users/del',{
        id:row.Id
      }).then(function(res){
        this_.get()
      }).catch(function(err){
        console.log(err)
      })
    }
  }
}

完整代码 ↓ ↓ ↓ ↓ github地址:https://github.com/jgsrty/jianshu_node 码云地址:https://gitee.com/RtyXmd/jianshu_node 测试代码写完了,接下来会重新部署一个,对node和vue代码进行优化与整理,下一步增加聊天室、完善登陆与注册(session,加密等)、评论、上传文件图片、爬虫爬取资源。。。 规划整理前后端代码(五)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 基于CodeIgniter&Vue-cli构建前后端分离

    这是正常CI给的初始页面,CI让我们更改welcome_message文件更换视图,具体方法在controllers/welcome中,但是我们并不需要,因为视...

    RtyXmd
  • (0)webpack学习笔记—哈喽~沃德

    webpack是一个现代javascript应用程序的模块打包器(module bundler),他会递归的构建一个依赖关系图,其中包含应用程序需要的每个模块,...

    RtyXmd
  • vue-cli3项目创建-配置-发布

    (2) 修改user module -- src/store/module/user.js

    RtyXmd
  • JavaScript 面向对象(封装、继承、多态)多种方式实现完全总结

    封装就是把抽象出来的数据和对数据的操作封装在一起,数据被保护在内部,程序的其它部分只有通过被授权的操作(成员方法),才能对数据进行操作。 创建对象实现封装可...

    csxiaoyao
  • Zepto这样操作元素属性

    本文作者:IMWeb 谦龙 原文出处:IMWeb社区 未经同意,禁止转载 前言 使用Zepto的时候,我们经常会要去操作一些DOM的属性,或元素本身...

    IMWeb前端团队
  • 第163天:js面向对象-对象创建方式总结

    缺点:跟上面的方式一样,只能临时用一下这个对象,不想作为new的构造模板是可以的。

    半指温柔乐
  • Zepto这样操作元素属性

    已经知道了如何使用attr方法,在开始分析attr实现源码之前,我们先了解一下这几个函数。

    IMWeb前端团队
  • Dart学习笔记(三)

    getUserInfo是自定义的函数,name和age是函数的参数,这两个参数都是必填,不然在调用的时候会报错。那么如何添加可选参数呢?如下:

    拉维
  • 前端需要了解的9种设计模式 什么是设计模式?设计模式的类型一. 结构型模式(Structural Patterns)二. 创建型模式(Creat

    设计模式是对软件设计开发过程中反复出现的某类问题的通用解决方案。设计模式更多的是指导思想和方法论,而不是现成的代码,当然每种设计模式都有每种语言中的具体实现方式...

    MudOnTire

扫码关注云+社区

领取腾讯云代金券