前端实现RESTful风格的两种方法: 使用ajax 和 使用隐藏_method

4 篇文章 0 订阅

现在推崇用RESTful的风格来使用http请求, 但是原生的form表单往往只支持GET和POST两种方式, 为了实现其他的比如PUT DELETE PATCH之类的请求, 就要做一些骚操作了;

我所知道比较常用的有两种方法:

一.使用ajax发送请求

比如我的页面中有一个名为nform的表单, 要以提交一个表项的更新内容, 那么我需要用PUT的方式发送这个请求, 我就可以设置在按下submit按钮的时候, 向服务器端发一个ajax请求, 把type设置为PUT即可;

            $("#submit").click(function () {
                $.ajax({
                    url: "ajaxPUT",
                    type: "PUT",
                    data:$('#nform').serialize(),
                    cache:false,
                    dataType: "json",
                    success: function(data){
                        alert(data);
                    },
                    error:function(err){

                    }
                });
            });

二.在表单中用隐藏的_method来设置请求

这也是我最先学会的方法, 感觉真心好用-.-
比如现在有我下面这样的一个表单要提交, 用于update一个内容, 虽然我在form的method中设置了post方法, 但我在表单内容中加了一行:

<input type="hidden" name="_method" value="PUT"/>

这样浏览器在识别到我的表单中有一个名为_method的hidden的这一项时, 就会把请求转换为PUT发送给服务器; 我们只需要用type="hidden"把这一行藏起来就好啦~

<form action="../Category" method="post">
    <input type="hidden" name="_method" value="PUT"/>
    <span>NAME</span>
        <input type="text" class="form-control" name="name" th:value="${c.name}">
        <input th:value="${c.id}" type="hidden" name="id">
        <button type="submit">Submit</button>
</form>
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值