普通ajax案例:
views.py
def testajax(request): h = request.POST.get('hostname') #拿到ajax传来的值 i = request.POST.get('ip') p = request.POST.get('port') b = request.POST.get('b_id') if h and len(h) < 5: #如果为空和长度小于5 models.Host.objects.create(hostname=h,ip=i,port=p,b_id=b) #存入主机表信息 return HttpResponse('OK') #存入成功返回‘OK’ else: return HttpResponse('fail') #不成功返回‘fail’
HTML
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> .hide{ display: none; } .shade{ position: fixed; top: 0; right: 0; left: 0; bottom: 0; background: black; opacity: 0.6; z-index: 100; } .add-modal{ position: fixed; height: 300px; 400px; top: 100px; left: 50%; z-index: 101; border: 1px solid black; background: white; margin-left: -200px; } </style> </head> <body> <h1>主机信息</h1> <div> <input type="button" id="add_host" value="添加"/> </div> <table border="1"> <thead> <tr> <th>序号</th> <th>主机名</th> <th>IP</th> <th>端口</th> <th>业务线ID</th> <th>业务线名称</th> </tr> </thead> <tbody> {% for row in v1 %} <tr host-id="{{ row.id }}" bid="{{ row.b_id }}"> <td>{{ forloop.counter }}</td> <td>{{ row.hostname }}</td> <td>{{ row.ip }}</td> <td>{{ row.port }}</td> <td>{{ row.b_id }}</td> <td>{{ row.b.caption }}</td> </tr> {% endfor %} </tbody> </table> <div class="shade hide"></div> <div class="add-modal hide"> <form action="/host" method="POST"> <div class="group"> <input type="text" id="host" placeholder="主机名" name="hostname"/> </div> <div class="group"> <input type="text" id="ip" placeholder="IP" name="ip"/> </div> <div class="group"> <input type="text" id="port" placeholder="端口" name="port"/> </div> <div class="group"> <select id="sel" name="b_id"> {% for op in b_list %} <option value="{{ op.id }}">{{ op.caption }}</option> {% endfor %} </select> </div> <input type="submit" value="提交"/> <input type="button" id="cancel" value="取消"/> </form>
# ajax提交按钮,id为ajax_submit在JS中进行判断 <input type="button" value="ajaxtijiao" id="ajax_submit" style="display: inline-block;padding: 5px;background: blue;color: black;"/> </div> <script src="static/js/jquery.min.js"></script> <script> $(function() { $('#add_host').click(function(){ $('.shade,.add-modal').removeClass('hide'); }); $('#cancel').click(function(){ $('.shade,.add-modal').addClass('hide'); }); }) $('#ajax_submit').click(function(){ #判断标签‘ajax_submit’的ajax提交事件 $.ajax({ url: "/testajax", #提交的url type: "POST", #提交方式 POST|GET data: {'hostname': $('#host').val(), 'ip': $('#ip').val(), 'port': $('#port').val(),'b_id': $('#sel').val()}, #提交的数据 success: function(data) { #返回的函数 if(data == "OK"){ #如果返回OK location.reload(); #重新加载本网页(刷新) }else{ alert(data); #不然返回一个弹出框 } } }) }) </script> </body> </html>
ajax回传json数据:
views.py
def testajax(request): import json #导入json包 ret = {'status': True, 'error': None, 'data': None} #json格式的字符串序列 try: #使用try来捕获错误 h = request.POST.get('hostname') i = request.POST.get('ip') p = request.POST.get('port') b = request.POST.get('b_id') if h and len(h) > 5: models.Host.objects.create( hostname=h, ip=i, port=p, b_id=b) else: ret['status'] = False #往字符串中写入错误字段 ret['error'] = "太短了" except Exception as e: #报错字段 ret['status'] = False #往字符串中写入错误字段 ret['error'] = "请求错误" return HttpResponse(json.dumps(ret)) #使用json工具把json格式转换成为字符串
HTML
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> .hide{ display: none; } .shade{ position: fixed; top: 0; right: 0; left: 0; bottom: 0; background: black; opacity: 0.6; z-index: 100; } .add-modal{ position: fixed; height: 300px; 400px; top: 100px; left: 50%; z-index: 101; border: 1px solid black; background: white; margin-left: -200px; } </style> </head> <body> <h1>主机信息</h1> <div> <input type="button" id="add_host" value="添加"/> </div> <table border="1"> <thead> <tr> <th>序号</th> <th>主机名</th> <th>IP</th> <th>端口</th> <th>业务线ID</th> <th>业务线名称</th> </tr> </thead> <tbody> {% for row in v1 %} <tr host-id="{{ row.id }}" bid="{{ row.b_id }}"> <td>{{ forloop.counter }}</td> <td>{{ row.hostname }}</td> <td>{{ row.ip }}</td> <td>{{ row.port }}</td> <td>{{ row.b_id }}</td> <td>{{ row.b.caption }}</td> </tr> {% endfor %} </tbody> </table> <div class="shade hide"></div> <div class="add-modal hide"> <form action="/host" method="POST"> <div class="group"> <input type="text" id="host" placeholder="主机名" name="hostname"/> </div> <div class="group"> <input type="text" id="ip" placeholder="IP" name="ip"/> </div> <div class="group"> <input type="text" id="port" placeholder="端口" name="port"/> </div> <div class="group"> <select id="sel" name="b_id"> {% for op in b_list %} <option value="{{ op.id }}">{{ op.caption }}</option> {% endfor %} </select> </div> <input type="submit" value="提交"/> <input type="button" id="cancel" value="取消"/> </form> <input type="button" value="ajaxtijiao" id="ajax_submit" style="display: inline-block;padding: 5px;background: blue;color: black;"/>
<span id="error_msg" style="color: red"></span> </div> <script src="static/js/jquery.min.js"></script> <script> $(function() { $('#add_host').click(function(){ $('.shade,.add-modal').removeClass('hide'); }); $('#cancel').click(function(){ $('.shade,.add-modal').addClass('hide'); }); }) $('#ajax_submit').click(function(){ $.ajax({ url: "/testajax", type: "POST", data: {'hostname': $('#host').val(), 'ip': $('#ip').val(), 'port': $('#port').val(), 'b_id': $('#sel').val()}, success: function(data) { # console.log(data); #获得回传数据,在console中打印出来
var obj = JSON.parse(data); #将字符串转换成为json格式 JSON.stringify():将json格式转换成为字符串
if(obj.status){ #取出json中status字段
location.reload();
}else{
$('#error_msg').text(obj.error); #取出 error字段并打印在标签‘error_msg’中
} } }) }) </script> </body> </html>
打印结果:
传递过来的json字符串,console打印出来了
使用ajax时最好使用 HttpResponse(json.dumps(data))返回一个字符串使用前端JSON.parse转换成为json格式在调用
不要使用render和redirect返回数据
案例:
$.ajax({
data: $('#edit_form').serialize(); #实现一句话提交数据,不用再写很多的对应关系
})