1. json
  json  是一种数据结构  跨平台跨语言
  1. python中json数据的转换
   1.数据类型
    字符串 数字 布尔值 列表 字典 None
    
   2. 序列化  python的数据类型  ——》  json字符串
    json.dumps(python的数据类型) 
    json.dump(python的数据类型,f)
   3. 反序列化  json字符串     ——》  python的数据类型
    json.loads(json字符串)
    json.load(json字符串,f)
    
  2. js中json数据的转换
   1.数据类型
    字符串  数字 布尔值 数组 对象  null
    
   2. 序列化  js的数据类型  ——》  json字符串
    JSON.stringify(js的数据类型)
    
   3. 反序列化  json字符串 ——》 JS的数据类型
    JSON.parse(json字符串)
    
  3. from django.http import JsonResponse    一般用来转换成字符串   字典就用这种方法
  JsonResponse({}) 
     JsonResponse([],safe=False)        传列表加这个参数
 2. ajax上传文件  及登录
视图代码:
# 上传文件
def upload(request):
    if request.is_ajax():
        f1 = request.FILES.get('f1')
        with open(f1.name, 'wb') as f:
            for i in f1.chunks():
                f.write(i)
        return HttpResponse('上传成功')
    return render(request, 'upload.html')
html代码:
<input type="file" id="my_file">
<button id="b1">上传</button>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="/static/ajax_setup.js"></script>
<script>
    $('#b1').click(
        function () {
            var form_obj = new FormData();
            form_obj.append('f1', $('#my_file')[0].files[0]);
            $.ajax({
                url: '/upload/',
                type: 'post',
                data: form_obj,
                processData: false,
                contentType: false,
                success: function (res) {
                    console.log(res)
                }
            })
        }
    )   
 
ajax登录代码
  # 登陆
from django.views import View
from django.http import JsonResponse
class Log(View):
    def get(self,request):
        return render(request,'log.html')
    def post(self,request):
        # 传一个字典
        ret={'status':0,'msg':''}
        user=request.POST.get('user')
        pwd=request.POST.get('pwd')
        # 找到第一个  不要用[0] 来取
        obj=models.User.objects.filter(name=user,pwd=pwd).first()
        if obj:
            # 给字典添加一个 登陆状态 及跳转网址
            ret['url']='/upload/'
            # 因为是字典新式 用JsonResponse
            return JsonResponse(ret)
        else:
            # 给字典添加  1为和设置用户密码错误
            ret['status']=1
            ret['msg'] = '用户名或密码错误'
            return JsonResponse(ret)
html代码:   
<p>
    用户名:<input type="text" id="user">
</p>
<p>
    密码:<input type="password" id="pwd">
</p>
<button id="b1">登录</button>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="/static/ajax_setup.js"></script>
<script>
$('#b1').click(function () {
    $.ajax({
        url:'/log/',
        type:'post',
        data:{
            user:$('#user').val(),
            pwd:$('#pwd').val()
        },
        success:function (res) {
            {#res 是调回来的对象 #}
            if (res.status ==0){
                {# res.url 相当于取字典里的值#}
                location.href = res.url
            }
            else {
                    alert(res.msg)
        }
        }
    })
})

ajax json用法 上传文件 登录的更多相关文章

  1. H5 FormData对象的使用——进行Ajax请求并上传文件

    XMLHttpRequest Level2 添加了一个新的接口——FormData .[ 主要用于发送表单数据,但也可以独立使用于传输键控数据.与普通的Ajax相比,它能异步上传二进制文件 ] 利用F ...

  2. jQuery Ajax使用FormData上传文件和其他数据,后端web.py获取

    参考博文: 通过jQuery Ajax使用FormData对象上传文件 方法一:使用<form>表单初始化FormData对象方式上传文件 前端(JQuery): <form enc ...

  3. HTML5+AJAX原生分块上传文件的关键参数设置

    processData:false 这是jquery.ajax的一个参数.默认值为true,表示会将非字符串对象自动变成k1=v1&k2=v2的形式,例如一个数组参数{d:[1,2]},到服务 ...

  4. Ajax 无刷新上传文件插件 uploadify 的使用

    在表单中无法直接使用 Ajax 上传文件,解决的思路可以是使用插件无刷新地上传文件,返回文件上传后的地址,然后把该地址作为 Ajax 的参数传递给服务器端进行数据库处理.可以使用 uploadify ...

  5. ajax:html5上传文件,上传之前可以实现本地预览

    本主题主要涉及两个新内容: 1.上传文件(主要使用了FormData) 2.本地预览(主要使用了FileReader) html5的FormData其实就是平时的Form表单,只是html5可以直接新 ...

  6. 使用FormData,进行Ajax请求并上传文件

    前段时间做了个手机端的图片上传,为了用户体验,用ajax交互,发现了FromData对象,这里有详细解释https://developer.mozilla.org/zh-CN/docs/Web/API ...

  7. Ajax通过FormData上传文件

    1.使用<form>表单初始化FormData对象方式上传文件 HTML代码 <form id="uploadForm" enctype="multip ...

  8. Springboot第三篇:与前端fetch通信(关于前端传输json数据上传文件等等前后端的处理)

    关于前端接口传递的方法,推荐按以下使用: 若要在服务器上创建资源,推荐使用POST方法 若要检索某个资源,推荐使用GET方法 若要更新资源,推荐使用PUT方法 若要删除某个资源,推荐使用DELETE方 ...

  9. ajax无刷新上传文件

    网页上传文件最简单的方式就是通过表单上传了,但是在提交表单的时候会导致网页刷新,但有的时候我们不想网页刷新,有什么办法呢,我们可以使用ajax上传文件来做到这一点.只有ajax还不行,还需要JavaS ...

随机推荐

  1. [LeetCode&Python] Problem 811. Subdomain Visit Count

    A website domain like "discuss.leetcode.com" consists of various subdomains. At the top le ...

  2. PHP vs Node.js

    网络正在处于一个日新月异的发展时代.服务器端开发人员在选择语言的时候非常困惑,有长期占主导地位的语言,例如C.Java和Perl,也有专注于web开发的语言,例如Ruby.Clojure和Go.只要你 ...

  3. Arpa’s obvious problem and Mehrdad’s terrible solution 思维

    There are some beautiful girls in Arpa’s land as mentioned before. Once Arpa came up with an obvious ...

  4. 《DSP using MATLAB》Problem 3.20

    代码: %% ------------------------------------------------------------------------ %% Output Info about ...

  5. 【JVM】jvm的jps命令

    jps -- Java Virtual Machine Process Status Tool 可以列出本机所有java进程的pid jps [ options ] [ hostid ] 选项 -q ...

  6. Git冲突和解决冲突

    1.产生冲突原因 产生:多个开发者同时使用或者操作git中的同一个文件,最后在依次提交和push的时候,第一个操作的是可以正常提交的,而之后的开发者想要执行pull(拉)和pull(push)操作的时 ...

  7. linux中tomcat内存溢出解决办法

    用命令 tail -f /root/apache-tomcat-6.0.20/logs/catalina.out(需要找到tomcat路径) 查看日志,查看是否有错误 linux中tomcat内存溢出 ...

  8. 让node支持es模块化(export、import)的方法

    node版本v7.9.0,支持了大部分es6的功能,但还不支持es6模块化(export.import). 检测ES6 可以使用es-checker来检测当前Node.js对ES6的支持情况. 使用命 ...

  9. JMeter和JMeterPlugin的下载安装

    JMeter和JMeterPlugin的下载安装 Apache Jmeter是一个100%的纯Java桌面应用,主要是针对web的压力和性能测试,但后来扩展到其他测试领域.Jmeter可以用于测试FT ...

  10. Scrapy下xpath基本的使用方法

    Scrapy是基于python的开源爬虫框架,使用起来也比较方便.具体的官网档:http://doc.scrapy.org/en/latest/ 之前以为了解python就可以直接爬网站了,原来还要了 ...