Node学习(九)031-管理系统之修改英雄——服务端get接口写法之req.query可以获取到url上所有的参数 & ajax请求数据之get请求写法

文章介绍了如何使用Node.js创建一个根据ID获取英雄信息的服务端接口,并通过jQuery的AjaxGET请求获取数据,然后在前端页面编辑英雄信息并渲染显示。同时,强调了req.query用于获取URL参数的方法。
摘要由CSDN通过智能技术生成

Node学习(九)031-管理系统之修改英雄——服务端get接口写法之req.query可以获取到url上所有的参数 & ajax请求数据之get请求写法

五、修改英雄

分析

  • 在index.html 中,给“编辑”挂超链接,链接到edit.html。并且要挂id参数

在这里插入图片描述

5.1 服务端:完成响应一个英雄的接口

链接和接口数据

在这里插入图片描述

app.js中,完成接口:

// 3. 根据id,获取一个英雄
/**
 * 浏览器在请求这个接口的时候,必须要传递id参数
 */
app.get('/getHeroById', (req, res) => {
    // 服务器端,首先要获取url中的id参数的值。req.query可以获取到url上所有的参数
    // console.log(req.query); // { id: '3', age: '24' }
    let id = req.query.id;
    if (!id || isNaN(id)) {
        res.send('参数错误');
        return;
    }
    // 如果id没有问题,则根据id查询一个英雄
    db('select * from heroes where id=?', id, (err, result) => {
        if (err) throw err;
        // result 的值是一个数组 : [{"id":3,"name":"嘉文四世","nickname":"德玛西亚皇子","file":null,"skill":null,"age":22,"sex":"男"}]
        res.send(result[0]);
    });
});

获取接口数据成功

在这里插入图片描述

执行 git add .git commit -m '完成一个根据id获取英雄的接口'

5.2 前端:页面刷新,请求一个英雄

单条数据

在这里插入图片描述

edit.html中。发送ajax请求到 getHeroById接口。将获取到的英雄的数组渲染到页面中:

// 页面刷新,先获取地址栏的id
    var id = location.search; // ?id=3
    $.get('/getHeroById' + id, function (res) {
      // res 是 一个对象
      // 挨个设置input的value
      $('#heroName').val(res.name);
      $('#heroNickName').val(res.nickname);
      $('#skillName').val(res.skill);
      $('.preview').attr('src', res.file);
    }, 'json');

执行 git add .git commit -m '修改英雄的时候,前端将获取的英雄数据渲染到页面中'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值