50.1、ajax介绍:

1、ajax是在不跳转当前url地址的情况偷偷的往后台发送数据做增删改数据的操作,如果成功返回结果刷新当前页面,失败则提醒,

使用 id 或 name 属性。

2、模态对话框中的数据已经随页面的加载而加载。模态对话框(对话框添加,删除,修改)适合使用ajax向后台传送数据,form表单

提交数据是url跳转的方式,使用name属性。

3、ajax data 的 value 值只支持字符串、数字、数组,不支持字典,前端传过来的数据都可看作字符串。

4、ajax语法格式:

(1)前提:ajax的使用需要下载并引入jQuery。

(2)格式:

$.ajax({

url: '/add_classes.html/',

// 后台地址

type: 'POST',

// 发送数据的方式 post、get

data: {'username':'root','password': '123'},

// 向后台发送的key-value的数据形式,value支持字符串、数字、数组、不支持字典。

success:function(arg){

// 回调函数,arg是服务端返回的数据,返回的是字符串。

window.location.reload();

// 刷新界面

},

error:function(){

# 由于网络错误或url地址错误而触发的回调函数。

}

});

50.2、ajax 其它应用方式:

1、Python序列化:

(1)字符串 = json.dumps(对象):

对象 -> 字符串

(2)对象 = json.loads(字符串):

字符串 -> 对象

2、JavaScript:

(1)字符串 = JSON.stringify(对象):

对象 -> 字符串

(2)对象 = JSON.parse(字符串):

字符串 -> 对象

(3)应用场景(数据传输时):

发送:字符串

接收:字符串 -> 对象

(4)用法:

1)发送数据时 data 中的 value 只是字符串或数字:

$.ajax({

url: 'http//www.baidu.com',

type: 'GET',

data: {'k1':'v1'},

success:function(arg){

// arg是字符串类型

// var obj = JSON.parse(arg)

// 将arg转化为对象

}

});

2)发送数据时 data 中的 value 是数组(traditional:true,):

$.ajax({

url: 'http//www.baidu.com',

type: 'GET',

data: {'k1':[1,2,3,4]},

traditional:true,

success:function(arg){

// arg是字符串类型

// var obj = JSON.parse(arg)

// 将arg转化为对象

}

});

3)发送数据时 data 中的 value 是字典:

$.ajax({

url: 'http//www.baidu.com',

type: 'GET',

data: {'k1': JSON.stringify({})},

success:function(arg){

// arg是字符串类型

// var obj = JSON.parse(arg)

// 将arg转化为对象

}

});

4)dataType: 'JSON',:

$.ajax({

url: 'http//www.baidu.com',

type: 'GET',

data: {'k1':'v1'},

dataType: 'JSON',

// 将arg直接转为对象

success:function(arg){

// arg是对象

}

});

3、事件委托:

$('要绑定标签的上级标签').on('click','要绑定的标签',function(){})

$('要绑定标签的上级标签').delegate('要绑定的标签','click',function(){})

50.3、小结:

1、使用新 URL 方式和对话框方式的区别:

(1)新 URL 方式:

1)独立的页面

2)数据量大或条目多

(2)对话框方式:

1)数据量小或条目少

2)增加,编辑

3)Ajax:考虑,当前页,td 中自定义属性

4)删除:对话框

2、示例:

(1)前端(.html):

<script src="/static/js/jquery-3.1.1.js"></script>

<script src="/static/plugins/bootstrap/js/bootstrap.js"></script>

<script>

/*

javascript功能集合

*/

$(function () {

bindDel();

bindDelConfirm();

});

/*

绑定删除按钮点击事件

*/

function bindDel() {

$('#tb').on('click','.del-row',function () {

$('#delModal').modal('show');

// 回去当前行的ID

var rowId = $(this).parent().parent().attr('nid');

$('#delNid').val(rowId);

});

}

/*

绑定删除提交事件

*/

function bindDelConfirm() {

$('#delConfirm').click(function () {

var rowId = $('#delNid').val();

console.log(rowId);

$.ajax({

url: '/del_student/',

type: 'GET',

data: {'nid': rowId},

success:function (arg) {

var dict = JSON.parse(arg);

if(dict.status){

$('tr[nid="'+ rowId+'"]').remove();

}

$('#delModal').modal('hide');

}

});

});

}

</script>

(2)后端(views.py):

from django.shortcuts import render

from django.shortcuts import HttpResponse

from app01 import models

import json

def del_student(request):

ret = {'status': True}

try:

nid = request.GET.get('nid')

models.Student.objects.filter(id=nid).delete()

except Exception as e:

ret['status'] = False

return HttpResponse(json.dumps(ret))

50.4、补充:

1、radio:是checked="checked";ajax:$('#eidtModal :radio[value="1"]').prop('checked',true);。

2、selected:是selected="selected";ajax:var values = $('#sel').val();。

3、zip:

4、JavaScript 字符串和对象之间的转换:

5、http响应:

6、FBV和SBV:

(1)

(2)

(3)

7、遍历表单:

var data = $('#fmForm表单的ID').serialize();

$.ajax({

data: $('#fm').serialize()

})

50、django工程(ajax)的更多相关文章

  1. Django工程读取mongodb并使用分页器

    pycharm开发django工程(二) 项目需求: 1. 从mongodb中读取数据,并显示到网页中 2. 在网页显示的每一页加入分页符 首先使用pycharm的企业版新建一个django的虚拟工程 ...

  2. Django工程的建立以及小网站的编写

    这篇博文会详细的介绍如何创建django工程,介绍我如何做了第一个网站.本文基于windows7安装了python2.7.12,Django1.8.18(LTS)版.采用的IDE为pycharm.建议 ...

  3. Django使用AJAX调用自己写的API接口

    Django使用AJAX调用自己写的API接口 *** 具体代码和数据已上传到github https://github.com/PythonerKK/eleme-api-by-django-rest ...

  4. python Django之Ajax

    python Django之Ajax AJAX,Asynchronous JavaScript and XML (异步的JavaScript和XML),一种创建交互式网页应用的网页开发技术方案. 异步 ...

  5. django 接受 ajax 传来的数组对象

    django 接受 ajax 传来的数组对象 发送:ajax 通过 POST 方式传来一个数组 接收:django 接受方式 array = request.POST.getlist(‘key[]’) ...

  6. python 全栈开发,Day75(Django与Ajax,文件上传,ajax发送json数据,基于Ajax的文件上传,SweetAlert插件)

    昨日内容回顾 基于对象的跨表查询 正向查询:关联属性在A表中,所以A对象找关联B表数据,正向查询 反向查询:关联属性在A表中,所以B对象找A对象,反向查询 一对多: 按字段:xx book ----- ...

  7. Django工程搭建

    -----环境安装 1.创建虚拟环境 mkvirtualenv django_py3_1.11 -p python3   2.安装django pip install django==1.11.11 ...

  8. python web框架 django 工程 创建 目录介绍

    # 创建Django工程django-admin startproject [工程名称] 默认创建django 项目都会自带这些东西 django setting 配置文件 django可以配置缓存 ...

  9. django学习笔记【001】django版本的确定&创建一个django工程

    2.3 查看当前的django版本 python3. -m django --version 2.3.1 创建一个django工程 django-admin startproject mysite 在 ...

随机推荐

  1. [bug] IDEA:application context not configured for this file

    参考 https://blog.csdn.net/a772304419/article/details/79680833

  2. 查看报错原因 sshd -t

    b for ssh.service failed because the control process exited with error code. See "systemctl sta ...

  3. LVM 相关知识

    LVM 相关知识 一.示例图 二.概念 名词 全称 释义 PV Physical Volume 物理硬盘.硬盘分区或者RAID磁盘阵列,先要创建pv VG Volume Group 卷组建立在物理卷之 ...

  4. Linux软件安装管理之——dpkg与apt-*详解 apt命令(dpkg和apt代替rpm)

    apt list *python* Nosee123关注赞赏支持   Linux软件安装管理之--dpkg与apt-*详解 [Linux软件安装管理系列]- - 传送门: - -<Linux软件 ...

  5. opencv——自适应阈值Canny边缘检测

    前言 Canny边缘检测速度很快,OpenCV中经常会用到Canny边缘检测,以前的Demo中使用Canny边缘检测都是自己手动修改高低阈值参数,最近正好要研究点小东西时,就想能不能做个自适应的阈值, ...

  6. 实现不同VLAN间的通信(单臂路由和链路聚合)

    单臂路由与链路聚合 1.单臂路由 1.1 链路类型 1.2 子接口 2. 链路捆绑 1.单臂路由 是指在路由器的一个接口上通过配置子接口,实现原来相互隔离的不同VLAN(虚拟局域网)之间的互联互通. ...

  7. QT绘制简易表盘

    1.简介 最近学习了一下QT,熟悉了一段时间后发现它的功能还是挺强大的,同时也比较方便用户上手去使用.现在就基于最近学习的内容,实现一个简易的带指针旋转功能的表盘.文中表盘的实现是基于QT的QPain ...

  8. ADAS虚拟车道边界生成

    ADAS虚拟车道边界生成 Virtual Lane Boundary Generation for Human-Compatible Autonomous Driving: A Tight Coupl ...

  9. NVIDIA FFmpeg 转码技术分析

    NVIDIA FFmpeg 转码技术分析 所有从 Kepler 一代开始的 NVIDIA GPUs 都支持完全加速的硬件视频编码,而从费米一代开始的所有 GPUs 都支持完全加速的硬件视频解码.截至 ...

  10. Covid经济型自主汽车

    Covid经济型自主汽车 Autonomous Vehicles in Covid Economy Covid经济已经对汽车行业产生了负面影响,更多的变化正在进行中,同时也带来了大量的不确定性.我们可 ...