django 笔记6 Ajax
感谢alex~
.Django请求生命周期
输入url 进入 urls(路由系统) 指向 views(视图函数)-》(获取模板) 里面的函数 再由函数返回字符串给用户 .路由系统
/index/ -> 函数或类.as_view()
/detail/(?P<nid>\d+) 函数(参数)或者类.as_view()(参数)
/detail/ name="a1" ->include('app01.urls')
->视图中:reverse
->模板中:{% url "a1" %} .视图函数
FBV:函数
def index(request,*args,**kwargs):
..
CBV:类
class Home(views.View):
def get(self,request,*args, **kwargs) 获取用户请求中的数据:
request.POST.get() #获取name =
request.GET.get()
request.FILES.get() #checkbox, select mutiple
request.POST.getlist()
request.GET.getlist()
request.FILES.getlist() request.path_info 获取当前请求的url 文件对象 = request.FILES.get()
文件对象.name 文件名
文件对象.size 文件大小字节
文件对象.chunks() 文件切片 需要for循环 f.write() #<form 特殊的设置></from> 获取用户请求分会数据:
render(request, "index.html" ,{'obj':,'k1':[,,,],'k2':{'name':"ljc"}}) #HTML模板的路径 不是url redirect(url) return redirect('/cmdb/user_info/') HttpResponse(字符串) .模板语言 <html>
<body>
<h1>{{ obj }}<h1> 单值
<h1> {{ k1. }}<h1>
<h1> {{k2.name}}<h1> {% for row in k1 %} #循环列表
<p>{{row}}<p>
{%endfor%} {%for x,y in k2.items %} keys,values,items
{{ x }} {{ y }}
{%endfor%} <body>
<html> .ORM
a.创建类和字段 执行命令生成数据库
class User(models.Model):
nid = models.IntergerField() 数字 不需要加长度
name = models.CharField(max_length=) 字符长度 只接收64个字符 python manage.py makemigrations
python manage.py migrate
# settings.py 注册APP需要添加 b.操作数据库 增删改查都是可以增字典 **dic
增
models.User.object.create(nid=,name="ljc") dic = {'name':'xx','nid':}
models.User.objects.create(**dic) obj = modeles.User.(nid=,name="ljc")
obj.save() 删
models.User.objects.filter(id=).delete()
改
models.User.objects.filter(id=).update(nid=,name="ljc")
dic = {'name':'xx','nid':}
models.User.objects.filter(id__gt=).update(**dic) 查
models.User.objects.filter(id=,name="root")查
models.User.objects.filter(id__gt=)
models.User.objects.filter(id__lt=)
models.User.objects.filter(id__lte=)
dic = {'name':'xx','nid__gt':} #nid大于19
models.User.objects.filter(**dic) 外键:
class UserType(models.Model):
caption = models.CharField(max_length=)
id caption
#.普通用户
#.VIP用户
#.游客 class User(models.Model):
age = models.IntergerFiled()
name = models.CharField(max_length = )
user_type = models.ForeignKey("UserType",to_field='id') #约束 但是生成数据时为user_type_id
name age user_type_id
ljc
zpt
cc v1 = models.Business.objects.all()
#QuerySet 对象 all() first()
#[obj(id, caption, code),obj2(id,caption,code) ]
{% for row in v1 %}
<li>{{row.id}}-{{row.caption}}-{{row.code}}</li>
{% endfor%} v2 = models.Business.objects.values('id','caption')
#QuerySet 字典
#[{'id':,'caption':"运维部"},{},{}] values变为字典了'
{% for row in v2 %}
<li>{{row.id}}-{{row.caption}}</li>
{% endfor%} v3 = models.Business.objects.values_list('id', 'caption')
#QuerySet 元组
#[(,运维部),(,开发)]
{% for row in v3 %}
<li>{{row.}}-{{row.}}</li>
{% endfor%} models.Business.objects.get(id=) 获取到一个对象 但一般不用
**models.Business.objects.filter(id=).first() 如果获取对象! 如果存在为true 如果不存在返回null 外键
v = models.Host.objects.filter(nid__gt=)
v[].b.caption ---> 通过点.来实现跨表查询 __双下划线跨表 filter后面想跨表时都用双下划线 b__caption b__code
v2 = models.Host.objects.filter(nid__gt=).values('nid','hostname','b_id','b__caption')
print(v2) 自循环 forloop.counter 从1开始
forloop.counter0 从0开始
forloop.revcounter 倒序排列
forloop.revcounter0 倒序0开始
forlopp.last {% for row in v1 %}
<a>{{forloop.counter}}<a>
{%endfor%} position:fixed absosulte relative .shade{
position:fixed;
top:;
rigth:;
left:;
bottom:;
background:black;
opacity:0.6;
z-index:;
}
.add-modal{
position:fixed;
height:300px;
width:400px;
top:100px;
left:%;
z-index:;
border:1px solied red;
background:white;
margin-left:-200px
}
.hide{
display:none;
} <select>
<option>
<option>
<select> redirect('/host')默认是以get
render(request,'host.html')以post Ajax提交
$.ajax({
url:'/host',
type:"POST 或者 GET",
data:{'k1':, "k2":"root"},
success: function(data){ #这个函数等着服务端发送回复请求
//data是服务器端返回的字符串
var obj = JSON.parse(data) }
}
})
内部都调用$.ajax 推荐还是$.ajax(
{}
)
$.get(url="",data={},)
$.getJson
$.post javascrip将字符串转为字典
data = '{1,2,3,4}'
var obj = JSON.parse(data); 将列表、字典转为字符串
li = [,,,]
JSON.stringify(li) 建议:永远让服务器端返回一个字典
return HttpResponse(json.dumps(字典))
python 字典/列表转为字符串
json.dumps(字典) python 字符串转为字典/列表
json.loads(字符串)
django 笔记6 Ajax的更多相关文章
- django 笔记15 ajax系列
参考 http://www.cnblogs.com/wupeiqi/articles/5703697.html # 原生操作# jQuery操作# 伪Ajax操作# XMLHttpReques 伪aj ...
- 【笔记】AJAX+SweetAlert插件实现删除操作
[笔记]AJAX+SweetAlert插件实现删除操作 Django AJAX SweetAlert 展示 SweetAlert 插件介绍 SweetAlert 是一个 JS 插件,能够完美替代 J ...
- 【笔记】AJAX基础
[笔记]AJAX基础 Django AJAX 知识储备:JSON 什么是 JSON JSON 是轻量级的文本数据交换格式 JSON 独立于语言和平台.JSON 解析器和 JSON 库支持许多不同的编 ...
- Django中的Ajax
Ajax 很多时候,我们在网页上请求操作时,不需要刷新页面.实现这种功能的技术就要Ajax!(本人定义,不可迷信) jQuery中的ajax就可以实现不刷新页面就能向后台请求或提交数据的功能,我们仍然 ...
- Web框架——Django笔记
Web框架--Django笔记 MVC和MTV MVC:Model.View.Controller MTV:Model.Template.View Django--MTV 1.创建Django程序 ...
- jQuery学习笔记之Ajax用法详解
这篇文章主要介绍了jQuery学习笔记之Ajax用法,结合实例形式较为详细的分析总结了jQuery中ajax的相关使用技巧,包括ajax请求.载入.处理.传递等,需要的朋友可以参考下 本文实例讲述了j ...
- django中的ajax组件
目录 django中的ajax 向服务器发送请求的途径 Ajax的特点 基于jquery实现的ajax请求 利用ajax实现计算器 利用ajax实现登陆认证 利用form表单进行文件上传 利用ajax ...
- 学习笔记:AJAX 跨域问题
学习笔记:AJAX 跨域问题 AJAX 跨域是浏览器的问题. 只要 xhr 请求,不同的域名就会出现 AJAX 跨域问题. JSONP 是一要简单方式,但是有很多弊端,需要修改服务端代码. JSONP ...
- Django框架 之 Ajax
Django框架 之 Ajax 浏览目录 AJAX准备知识 AJAX与XML的比较 AJAX简介 jQuery实现的ajax AJAX参数 AJAX请求如何设置csrf_token 序列化 一.AJA ...
随机推荐
- HDU 4329 Contest 3
果然换个编译器就过了.总的来说,不难,不过就是处理一些空格.学习了一个新的类 istringstream可以按空格划分.然后,那条式子要理解. 式子的意义是: 找到一个串,该串在query中是第几个找 ...
- HDU 2865
和上题一样,但K较大,不能直接用矩阵来写.这个矩阵必定是这个形式的. 0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 0 分成对角线上元素B与非对角线上元素A k: 1 2 3 4 ... ...
- 【JavaEE WEB 开发】Tomcat 具体解释 Servlet 入门
转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/47146817 一. Tomcat 下载安装配置 1. Tomcat 下载 T ...
- nginx源代码分析--从源代码看nginx框架总结
nginx源代码总结: 1)代码中没有特别绕特别别扭的编码实现.从变量的定义调用函数的实现封装,都非常恰当.比方从函数命名或者变量命名就能够看出来定义的大体意义,函数的基本功能,再好的架构实如今编码习 ...
- javaScript中的事件对象event
事件对象event,每当一个事件被触发的时候,就会随之产恒一个事件对象event,该对象中主要包括了关于该事件的基本属性,事件类型type(click.dbclick等值).目标元素target(我的 ...
- [Android] Android开发优化之——对界面UI的优化(1)
在Android应用开发过程中,屏幕上控件的布局代码和程序的逻辑代码通常是分开的.界面的布局代码是放在一个独立的xml文件中的,这个文件里面是树型组织的,控制着页面的布局.通常,在这个页面中会用到很多 ...
- m_Orchestrate learning system---二十二、html代码如何变的容易
m_Orchestrate learning system---二十二.html代码如何变的容易 一.总结 一句话总结:(结构清晰之后构建页面就变得超级容易了)(多做多用一下子就熟了) 1.文章显示页 ...
- xBIM 基础07 创建WebBIM文件
系列目录 [已更新最新开发文章,点击查看详细] xBIM项目提供了一个IFC文件的Web查看器.当你想把IFC转换成紧凑的WexBIM时,需要 xBIM Essentials 和 xBIM G ...
- Linux下Python编译安装
1.安装python3 1.1下载python源码包 网址:https://www.python.org/downloads/release/python-362/ 下载地址:https://www. ...
- Swift学习笔记(9):枚举
目录: 基本语法 关联值 原始值 枚举为一组相关的值定义了一个共同的类型. ・可以给枚举成员指定原始值类型:字符串,字符,整型值或浮点数等 ・枚举成员可以指定任意类型的关联值存储到枚举成员中 ・枚举可 ...