• json格式
      • stringify与parse
      • Ajax
        • GET方式
        • POST方式
      • serialize序列化
      • 案例

json格式

合格的json对象:

["one","two","three"]

{ "one": 1,"two": 2,"three": 3 }

{"names": ["张三","李四"] }

[ { "name": "张三"},{"name": "李四"} ]

不合格的json对象:

{ name: "张三",'age': 32 }                     // 属性名必须使用双引号

[32,64,128,0xFFF] // 不能使用十六进制值

{ "name": "张三","age": undefined }            // 不能使用undefined

{ "name": "张三","birthday": new Date('Fri,26 Aug 2011 07:13:10 GMT'),"getName":  function() {return this.name;}    // 不能使用函数和日期对象
}

stringify与parse

JSON.parse():     用于将一个 JSON 字符串转换为 JavaScript 对象 
eg:
console.log(JSON.parse('{"name":"Yuan"}'));
console.log(JSON.parse('{name:"Yuan"}')) ;   // 错误
console.log(JSON.parse('[12,undefined]')) ;   // 错误



JSON.stringify(): 用于将 JavaScript 值转换为 JSON 字符串。 
eg:  console.log(JSON.stringify({'name':"egon"})) ;
JSON.parse('{}');              // {}
JSON.parse('true');            // true
JSON.parse('"foo"');           // "foo"
JSON.parse('[1,5,"false"]'); // [1,"false"]
JSON.parse('null');            // null
JSON.parse('1');               // 1

Ajax

AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步Javascript和XML”。即使用Javascript语言与服务器进行异步交互,传输的数据为XML(当然,传输的数据不只是XML)。

同步交互:客户端发出一个请求后,需要等待服务器响应结束后,才能发出第二个请求;
异步交互:客户端发出一个请求后,无需等待服务器响应结束,就可以发出第二个请求。

AJAX除了异步的特点外,还有一个就是:浏览器页面局部刷新;(这一特点给用户的感受是在不知不觉中完成请求和响应过程)

GET方式

url如下

url(r'^login/$',views.login ),url(r'^safly/$',views.safly ),

视图函数如下:
view.py

from django.shortcuts import render,redirect,HttpResponse,reverse
def login(request):
    return render(request,"login.html")

def safly(request):
    username = request.GET.get("username")
    pwd = request.GET.get("pwd")

    if username == "safly" and pwd == "123":
        res = username + pwd
        return HttpResponse(res)

login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <Meta charset="UTF-8">
    <Meta http-equiv="X-UA-Compatible" content="IE=edge">
    <Meta name="viewport" content="width=device-width,initial-scale=1">
    <title>Title</title>
    <script src="/static/js/jquery-3.2.1.min.js"></script>
</head>
<body>


<input type="text">
<button id="id_btn">提交</button>


<script> $("#id_btn").click(function () { $.ajax({ url: "/safly/",type: "GET",data: {username: "safly",pwd: "123"},success: function (data) { console.log(data) } }) }) </script>
</body>
</html>

我们测试如下:

点击提交按钮,控制台输出

[30/Jan/2018 17:44:37] "GET /safly/?username=safly&pwd=123 HTTP/1.1" 200 8

浏览器输出

safly123

以上data改成data: {“username”: “safly”,pwd: “123”},也可以
会自动给转换成json格式的类型

POST方式

如果将上例中的type改成type: “POST”,
按着之前的流程会报错如下:

Forbidden (CSRF token missing or incorrect.): /safly/

我们需要进行添加csrf参数

login.html

<!DOCTYPE html> <html lang="en"> <head> <Meta charset="UTF-8"> <Meta http-equiv="X-UA-Compatible" content="IE=edge"> <Meta name="viewport" content="width=device-width,initial-scale=1"> <title>Title</title> <script src="/static/js/jquery-3.2.1.min.js"></script> </head> <body> <input type="text" id="input_text"> <button id="id_btn">提交</button> {% csrf_token %} <script> $("#id_btn").click(function () { $.ajax({ url: "/safly/",type: "POST",data: { "username": "safly",pwd: "123",csrfmiddlewaretoken: $("[name='csrfmiddlewaretoken']").val() },success: function (data) { var data = JSON.parse(data) console.info(data.is_regist) if (data.is_regist) { $("#input_text").val("已经注册") } } }) }) </script> </body> </html> 

views.py

from django.shortcuts import render,reverse


def login(request):
    return render(request,"login.html")


def safly(request):
    username = request.POST.get("username")
    pwd = request.POST.get("pwd")


    response={"is_regist":True}



    if username == "safly" and pwd == "123":

        pass
    else:

        response["is_regist"] = False
    import  json

    response = json.dumps(response)


    return HttpResponse(response)

或者如下的方式:

<script src="{% static 'js/jquery.cookie.js' %}"></script> $.ajax({ headers:{"X-CSrftoken":$.cookie('csrftoken')},})
$.ajaxSetup({ data: {csrfmiddlewaretoken: '{{ csrf_token }}' },});

serialize序列化

不在标签内的表单控件不会被提交、没有name属性的表单控件不会被提交、带有disabled属性的表单控件不会被提交、没有被选中的表单控件不会被提交。

<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript"> $(document).ready(function(){ $("button").click(function(){ $("div").text($("form").serialize()); }); }); </script>
</head>
<body>
<form action="">
First name: <input type="text" name="FirstName" value="Bill" /><br />
Last name: <input type="text" name="LastName" value="Gates" /><br />
</form>

<button>序列化表单值</button>
<div></div>
</body>
</html>

结果如下:

案例


先来看login页面

url(r'^login/$',views.login,name="login"),
from django.shortcuts import render,reverse

from . import  models
def login(request):

    return render(request,"login.html")

直接渲染login.html页面

<!DOCTYPE html> <html lang="en"> <head> <Meta charset="UTF-8"> <Meta http-equiv="X-UA-Compatible" content="IE=edge"> <Meta name="viewport" content="width=device-width,initial-scale=1"> <title>Title</title> <script src="/static/js/jquery-3.2.1.min.js"></script> </head> <body> <p> <label for="name">姓名:<input type="text" name="name" id="name"></label> <span id="name_span"></span> </p> <p> <label for="pwd">密码:<input type="text" name="pwd" id="pwd"></label> <span id="pwd_span"></span> </p> <input type="button" value="注册" id="btn_sumit"> {% csrf_token %} <script> {##校验姓名#} $("#name").blur(function () { $.ajax({ url: "/validate/",data: {name: $("#name").val()},success: function (data) { var data = JSON.parse(data) console.info(data) if (data.is_regist) { {#已经注册#} $("#name_span").html(data.name + "已经注册").css("color","red") } else { {#没有注册#} $("#name_span").html(data.name + "可以使用").css("color","black") } } }) }) {#校验密码#} $("#btn_sumit").click(function () { $.ajax({ url: "/register/",data: { name: $("#name").val(),pwd: $("#pwd").val(),csrfmiddlewaretoken: $('[name="csrfmiddlewaretoken"]').val() },success: function (data) { console.info(data) if(data == "ok"){ window.location.href="/index/"; //在同当前窗口中打开窗口 } } }) }) </script> </body> </html> 

校验姓名

url(r'^validate/$',views.validate,name="validate"),
def validate(request):
    my_name = request.GET.get("name")

    user = models.User.objects.filter(name=my_name)

    response_dic = {"name":my_name,"is_regist":False}

    if user:
        response_dic["is_regist"] = True
        response_dic["name"] = user[0].name

    import  json

    data = json.dumps(response_dic)

    print(data)
    #字符串
    return HttpResponse(data)

注册利用ajax,不用form

url(r'^register/$',views.register,name="register"),url(r'^index/$',views.index,name="index"),
def register(request):
    if request.method == "POST":

        name = request.POST.get("name")
        pwd = request.POST.get("pwd")

        print(name,"------",pwd)

        models.User.objects.create(name=name,pwd=pwd)

        return HttpResponse("ok")

def index(request):
    return render(request,"index.html")

Ajax-get\post请求、serialize序列化的更多相关文章

  1. ios – 将视频分享到Facebook

    我正在编写一个简单的测试应用程序,用于将视频从iOS上传到Facebook.由于FacebookSDK的所有文档都在Objective-C中,因此我发现很难在线找到有关如何使用Swift执行此操作的示例/教程.到目前为止我有这个在我的UI上放置一个共享按钮,但它看起来已禁用,从我读到的这是因为没有内容设置,但我看不出这是怎么可能的.我的getVideoURL()函数返回一个NSURL,它肯定包含视

  2. ios – 错误域= NSURLErrorDomain代码= -1003“找不到具有指定主机名的服务器

    当我尝试在设备上运行应用程序时出现此错误.当我在模拟器上运行它并且post请求正常工作时,我没有收到此错误.这是我的代码片段:任何帮助表示赞赏.谢谢解决方法此错误通常会提示DNS相关问题.检查设备上的DNS设置并确认您可以使用Safari或其他浏览器浏览互联网.如果有一个url,你可以在同一台服务器上获取,尝试直接在设备上的Safari中访问它.

  3. ios – Xcode Bot:如何在post触发器脚本上获得.ipa路径?

    我正在使用机器人来存档iOS应用程序,我需要获取.ipa产品路径才能将其发布到我们的分发系统中.机器人设置:并使用脚本打印所有env变量,其中不包含ipa文件的路径.此外,一些变量指向不存在的目录,即:XCS_OUTPUT_DIR这里的env变量输出:除此之外,我还能够确认.ipa文件是在另一个文件夹中创建的(/IntegrationAssets//

  4. ios – 使用CocoaPods post install hook将自定义路径添加到HEADER_SEARCH_PATHS

    解决方法在Podfile中定义一个方法:然后在post_install中调用该方法:

  5. iOS7 Safari中的全屏模式

    我正在使用SenchaTouch开发移动网站.在iOS7Safari中,我无法创建顶级地址栏和下面的工具栏消失了.Sencha过去常常处理iOS6,但iOS7最近的一些变化导致了这个问题.http://java.dzone.com/articles/safari-ios-7-and-html5我阅读了上面的链接&对于HTML5游戏而言,这似乎也是一个问题.一些其他应用程序.适用于iOS6的旧win

  6. ios – 如何使用新的Apple Swift语言发布JSON

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  7. ios – POST请求使用application / x-www-form-urlencoded

    后端开发人员在POST请求中给出了这些说明:>路线:{url}/{app_name/{controller}/{action}控制器和动作应该是小帽子.>API测试链接:http:****************>请求应该使用POST方法.>参数应通过请求内容体(FormUrlEncodedContent)传递.>参数应该是json格式.>参数是关键的.在协议中没有经验5,我搜索并结束了我的代码.

  8. 从iOS应用程序发送帖子到PHP脚本不工作…简单的解决方案就像

    我之前已经做了好几次了但是由于某些原因我无法通过这个帖子…我尝试了设置为_POST且没有的变量的PHP脚本……当它们未设置为发布时它工作精细.这是我的iOS代码:这里是PHP的一大块,POST变量不在正确的位置?我想这对于更有经验的开发人员来说是一个相当简单的答案,感谢您的帮助!解决方法$_POST是一个数组,而不是一个函数.您需要使用方括号来访问数组索引:

  9. ios – 在HTTPBody中设置NSDictionary并使用POST方法发送

    我想用POST方法调用Web服务.我需要发布一个带有URL的字典.我的Web服务参数如下:以下是我的要求:但是我收到以下错误:服务器拒绝此请求,因为请求实体的格式不受所请求方法所请求资源的支持解决方法请找到以下代码,将数据发布到Web服务.请注意这是我在我的一个申请中使用的样本.希望这可以帮助.从您的评论“服务器拒绝此请求”服务器是否支持JSON或XML格式.

  10. ios – 如何使用Firebase存储喜欢的内容

    我有一个关于firebase的后端,有像Facebook这样的帖子.所以我需要喜欢这些帖子的功能.问题是如何存储喜欢帖子的喜欢和用户?

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部