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. [刷题] 剑指Offer 面试题7:重建二叉树

    题目:输入某二叉树的前序遍历和中序遍历结果,重建该二叉树.(假设输入的前序和中序遍历结果中都不含重复数字) 思路 构建二叉树的两个函数:Construct().ConstructCore() Cons ...

  2. 【BIGDATA】在Centos上部署ElasticSearch 7.3.2及kibana

    一.下载: 首先,下载ElasticSearch和kibana安装包,版本自选,官方下载页https://www.elastic.co/cn/downloads/ 二.版本检查 很重要的一步,要检查C ...

  3. centos 6 x64 yum(sohu)

    centos 6 x64 yum(sohu) weixin_34405354 2012-08-23 10:07:35 24 收藏 文章标签: 运维 版权 [base] name=Base baseur ...

  4. 命令stat anaconda-ks.cfg会显示出文件的三种时间状态(已加粗):Access、Modify、Change。这三种时间的区别将在下面的touch命令中详细详解:

    7.stat命令 stat命令用于查看文件的具体存储信息和时间等信息,格式为"stat 文件名称". stat命令可以用于查看文件的存储信息和时间等信息,命令stat anacon ...

  5. Linux 系统优化-workstation实践

    Linux 系统优化 关闭SELinux [root@workstation ~]# sed -i 's#SELINUX=enforcing#SELINUX=disabled#g' /etc/seli ...

  6. 回车与换行的区别:CRLF、CR、LF

    引言 以下是 MySQL 8 导出数据的窗口,导出数据时需要选择记录分隔符,这就需要你明白 CRLF.CR 和 LF 分别代表什么,有何区别,否则可能导出数据会出现莫名其米的问题. 名词解释 CR:C ...

  7. Docker的介绍和安装(1)

    一.虚拟化简介 1.虚拟化概念 计算机虚拟化(Computing Virtualization),一种资源管理技术,是指通过虚拟化技术将一台计算机的各种实体资源 , 如处理器 , 网络 , 内存及存储 ...

  8. GPIO端口上拉下拉 与 硬件图的上拉下拉

    硬件图上的上拉下拉: 没有触发时默认接到IO的是高电平就是上拉: 没有触发时默认接到IO的是低电平就是 下拉: (2)对应GPIO的配置 配置与你的外围电路息息相关: 比如下图: 你只能配置为上拉: ...

  9. 原生基础js脚本实现--在线答题系统

    全部代码在最下面----需要的直接往下翻 html方面的代码  : 正确的答案 value=s <!DOCTYPE html> <html lang="en"&g ...

  10. 聊聊java工程师换工作那些事

    最近有个读者在苦恼一件事,那就是有大公司在挖他,他要不要从所在的小公司,跳槽到大公司,前提是两家公司的待遇基本一致.由这个问题结合自己多年的工作经验,来谈谈java工程师要不要跳槽,何时跳槽,怎么跳槽 ...