ajax实现添加数据

前端部分

javascript 复制代码
function bindBtnAddEvent() {
     $("#btnAdd").click(function () {

          $(".error_msg").empty();

          $.ajax({
               url: '/task/add/',
               type: 'post',
               data: $('#formAdd').serialize(),
               dataType: "JSON",
               success: function (res) {
                    if (res.status) {
                            alert("添加成功");
                            location.reload();
                   } else {
                            console.log(res.error);
                            $.each(res.error, function (name, data) {
                                console.log(name);
                                $("#id_" + name).next().text(data[0]);
                           })
                       }
                    }
                })
          })
    }

点击后,发送ajax请求 。以post方式向/task/add/地址发送表单数据。

python 复制代码
@csrf_exempt
def task_add(request):
    #print(request.POST)
    #校验
    form=TaskModelForm(data=request.POST)
    if form.is_valid():
        form.save()
        data_dict={"status": True}
        return HttpResponse(json.dumps(data_dict))
    print(type(form.errors))
    data_dict={"status": False,'error':form.errors}
    return HttpResponse(json.dumps(data_dict))

TaskModelForm是自定义的类

后台接收到数据,以TaskModelForm类接收POST请求发送的数据。

如果数据有效,保存到数据库,并给前段返回HttpResponse(json.dumps(data_dict)),其中

data_dict={"status":True}

如果无效,data_dict={"status": False,'error':form.errors} 向前端发送 HttpResponse(json.dumps(data_dict))

javascript 复制代码
success: function (res) {
    if (res.status) {
        alert("添加成功");
        location.reload();
    } else {
        console.log(res.error);
        $.each(res.error, function (name, data) {
            console.log(name);
            $("#id_" + name).next().text(data[0]);
        })
    }
}

请求发送过后,获取响应。

如果res.status=True,添加成功 并且刷新页面

否则,

相关推荐
emmm45912 分钟前
前端中常用的几种单位写法及其解释
前端
黄毛火烧雪下28 分钟前
HTML 之 <div> 和 <span>
前端·html
小林熬夜学编程31 分钟前
【Linux系统编程】第三十弹---软硬链接与动静态库的深入探索
服务器·c语言·开发语言·前端·c++·算法
2401_8572979138 分钟前
招联金融校招内推2025
java·前端·算法·金融·求职招聘
前端郭德纲39 分钟前
HTML该如何性能优化?
前端·性能优化·html
pink大呲花1 小时前
css如何制作瀑布流
前端·css
小小李程序员1 小时前
CSS3旋转、平移、缩放、倾斜
前端·css·css3
VaporGas1 小时前
SpringMVC Controller返回值技巧:ModelAndView vs String的实战对比
java·开发语言·前端·spring·springmvc·modelandview
裴嘉靖1 小时前
JavaScript中引用数据类型的浅拷贝
前端·javascript
乐多_L1 小时前
点击置顶按钮,返回到顶部
java·前端·javascript