zoukankan      html  css  js  c++  java
  • ajax

    1. choice参数

    class User(models.Model):
        username = models.CharField(max_length=32)
        password = models.IntegerField()
        choices = (
        (1,'male'),
        (2,'female'),
        (3,'others'),
        )
        gender = models.IntegerField(choices=choices)
        """
        1.如果存的是上面元组中数字会怎么样
        2.如果存的数字不在元组范围内又会怎样
            数字没有对应关系 是可以存的
        """
        
    from app01 import models
    user_obj = models.User.objects.filter(pk=4).first()
    print(user_obj.username)
    print(user_obj.gender)   # 获取的是对应的数字
    # 针对choices字段 如果你想要获取数字所对应的中文 你不能直接点字段
    # 固定句式   数据对象.get_字段名_display()  当没有对应关系的时候 该句式获取到的还是数字
    print(user_obj.get_gender_display())
    

    2. MTV与MVC模型

    django号称是MTV框架,其实他还是MVC框架
    MTV:
    	M:models(模型): 负责业务对象与数据库的对象(ORM)
    	T: templates(模版): 负责如何把页面展示给用户
        V: views(视图): 负责业务逻辑,并在适当的时候调用Model和Template
    MVC:
        M:models(模型): 业务对象与数据库的对象(ORM)
        V: views(视图): 与用户的交互(页面)
        C: contronner(路由匹配): 接受用户的输入调用模型和视图完成用户的请求
    

    3. ajax

    1.异步提交
    	同步异步:描述的任务的提交方式
    		同步:提交任务之后 原地等待任务的返回结果 期间不干任何事儿
            异步:提交任务之后 不愿地等待 直接执行下一行代码 任务的返回通过回调机制
        阻塞非阻塞:程序的运行状态
    		程序运行的三状态图
            
    2.局部刷新
    	一个页面 不是整体刷新 而是页面的某个地方局部刷新
    
            
    Ajax是一门js的技术,基于原生js开发的,但是用原生的js写代码过于繁琐
    
    用jQuery实现ajax
            
    AJAX 最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。(这一特点给用户的感受是在不知不觉中完成请求和响应过程)
    

    4. jQuery实现的AJAX

    # 展示一个前端页面  页面上有三个输入框  前两个框输入数字 点击按钮朝后端发请求  页面不刷新的情况下 完成数字的加法运算
    # views.py
    def index(request):
        if request.is_ajax():
            if request.method == 'POST':
                t1 = request.POST.get('t1')
                t2 = request.POST.get('t2')
                res = eval(t1) + eval(t2)
                return HttpResponse(res)
        return render(request,'index.html')
    

    index.html

    <input type="text" id="t1"> + <input type="text" id="t2"> = <input type="text" id="t3">
    <p>
        <button id="b1">计算</button>
    </p>
    <script>
        $('#b1').on('click',function () {
            // 朝后端提交post数据
            $.ajax({
                // 1.到底朝后端哪个地址发数据
                url:'',     // 专门用来控制向后端提交数据的地址,不写默认就是朝当前地址提交
                // 2.到底发送什么请求
                type:'post',   // 专门指定ajax发送的请求方式
                // 3.发送的数据到底是什么
                data:{'t1':$('#t1').val(),'t2':$('#t2').val()},
                // 4.异步提交的任务 需要通过回调函数来处理
                success:function (data) {   // data形参指代的就是异步提交的返回结果
                    // 通过DOM操作将内容 渲染到标签内容上
                    $('#t3').val(data)
                }
            })
        })
    </script>
    

    5. Ajax传json格式数据

    '''
    django后端针对json格式的数据 不会自动帮你解析 会直接原封不动的给你放到request.body中
    你可以手动处理 获取数据
    '''
    
    def index(request):
        if request.is_ajax():
            if request.method == 'POST':
                json_bytes = request.body
                json_str = json_bytes.decode('utf-8')
                json_dit = json.loads(json_str)
                print(json_dit,type(json_dit))
        return render(request,'index.html')
    
    '''
    index.py
    $('#b1').on('click',function () {
        $.ajax({
            url:'',
            type:'post',
            // 告诉后端你当前的数据格式 到底是什么类型
            contentType:'application/json',
            data:JSON.stringify({'username':'wzh','password':123}),
            success:function (data) {
                alert(data)
            }
        })
    })
    '''
    

    6. AJAX传文件

    # AJAX传文件需要利用内置对象 Formdata
    # 该对象既可以传普通的键值 也可以传文件
    
    # views.py
    def ajax_file(request):
        if request.is_ajax():
            if request.method == 'POST':
                print(request.POST)
                print(request.FILES)
                return HttpResponse('收到了')
        return render(request,'ajax_file.html')
    

    ajax_file.html

    <input type="text" name="username" id="t1">
    <input type="password" name="password" id="t2">
    <input type="file" name="myfile" id="t3">
    <button id="b1">提交</button>
    
    <script>
    $('#b1').on('click', function () {
        // 1.先生成一个formdata对象
        var myFormData = new FormData();
        // 2.朝对象中添加普通的键值
        myFormData.append('username',$('#t1').val());
        myFormData.append('password',$('#t2').val());
        // 3.朝对象中添加文件数据
            // 1.先通过jquery查找到该标签
            // 2.将jquery对象转换成原生的js对象
            // 3.利用原生js对象的方法 直接获取文件内容
        myFormData.append('myfile',$('#t3')[0].files[0]);
        $.ajax({
            url: '',
            type: 'post',
            data: myFormData,   // 直接丢对象
            // ajax传文件 一定要指定两个关键性的参数
            contentType: false,   // 不用任何编码 因为formdata对象自带编码 django能够识别该对象
            processData: false,   // 告诉浏览器不要处理我的数据 直接发就行
            success: function (data) {
                alert(data)
            }
        })
    })
        
    <!--
    jax传文件需要注意的事项:
    	1.利用formdata对象 能够简单的快速传输数据 (普通键值 + 文件)
    	2.参数:
    		data:formdata对象
            contentType:false
            processData:false
    -->
    

    7. contentType前后端传输数据编码格式

    '''
    form表单 默认的提交数据的编码格式是urlencoded
    	urlencoded
    		username=admin&password=123这种就是符合urlencoded数据格式
                    
    		django后端针对username=admin&password=123的urlencoded数据格式会自动解析,将结果打包给request.POST 用户只需要从request.POST即可获取对应信息
                   
    	formdata
    		django后端针对formdata格式类型数据 也会自动解析,但是不会放到request.POST中而是给你放到了request.FILES中
                
    ajax  ajax默认的提交数据的编码格式也是urlencoded
    	username=jason&password=123
        总结:django后端针对不同的编码格式数据 会有不同的处理机制以及不同的获取该数据的方法
        
    前后端在做数据交互的时候 一定一定要表明你所发的的数据到底是什么格式
    前段后交互,你的数据是什么格式 你就应该准确无误告诉别人是什么格式
    '''
    

    8. 序列化组件

    # 将用户表的数据 查询出来 返回给前端
    # 给前端的是一个大字典 字典里面的数据的一个个的字段
    from app01 import models
    from django.core import serializers
    def ser(request):
        user_queryset = models.User.objects.all()
        # user_list = []
        # for user_obj in user_queryset:
        #     user_list.append({
        #         'username':user_obj.username,
        #         'password':user_obj.password,
        #         'gender':user_obj.get_gender_display(),
        #     })
        res = serializers.serialize('json',user_queryset)
        print(res)
        return render(request,'ser.html',locals())
    

    9. ajax + sweetalert

    """
    当你是用ajax做前后端 交互的时候 
    你可以考虑返回给前端一个大字典
    """
    # views.py
    from django.http import JsonResponse
    def sweet(request):
        if request.method == 'POST':
            back_dic = {'core':1000,'msg':''}
            delete_id = request.POST.get('delete_id')
            models.User.objects.filter(pk=delete_id).delete()
            back_dic['msg']='后端传的:删除成功'
            return JsonResponse(back_dic)
        user_queryset = models.User.objects.all()
        return render(request,'sweet.html',locals())
    

    sweet.html

    <div class="container-fluid">
        <div class="row">
            <div class="col-md-8 col-md-offset-2">
                <h1 class="text-center">用户数据</h1>
                <table class="table table-bordered table-hover table-striped">
                    <thead>
                        <tr>
                            <th>编号</th>
                            <th>用户名</th>
                            <th>密码</th>
                            <th>性别</th>
                            <th>操作</th>
                        </tr>
                    </thead>
                    <tbody>
                        {% for user_obj in user_queryset %}
                            <tr>
                                <td>{{ forloop.counter }}</td>
                                <td>{{ user_obj.username }}</td>
                                <td>{{ user_obj.password }}</td>
                                <td>{{ user_obj.get_gender_display }}</td>
                                <td>
                                    <a href="#" class="btn btn-primary btn-sm">编辑</a>
                                    <a href="#" class="btn btn-danger btn-sm cancel" delete_id="{{ user_obj.pk }}">删除</a>
                                </td>
                            </tr>
                        {% endfor %}
    
                    </tbody>
                </table>
    
            </div>
        </div>
    </div>
    
    <script>
        $('.cancel').on('click',function () {
            var $btn = $(this)
            swal({
                title: "确定删除嘛?",
                text: "你会失去这条数据!",
                type: "warning",
                showCancelButton: true,     // 是否显示取消按钮
                confirmButtonClass: "btn-danger",   // 确认按钮的样式类
                confirmButtonText: "删除它!",   // 确认按钮文本
                cancelButtonText: "不删了!",    // 取消按钮文本
                closeOnConfirm: false,     // 点击确认按钮不关闭弹框
                showLoaderOnConfirm: true   // 显示正在删除的动画效果
            },
            function () {
                $.ajax({
                    url:'',
                    type: 'post',
                    data:{'delete_id':$btn.attr('delete_id')},
                    success:function (data) {
                        if (data.core == 1000){
                            swal(data.msg, "你已成功删除数据", "success");
                            // 1.直接刷新页面
                            {#window.location.reload()#}
                            // 2.通过DOM操作 实时删除
                            $btn.parent().parent().remove()
                        }else {
                            swal("发生未知错误","未知哪里有错",'info')
                        }
                    }
                })
    
            });
        })
    </script>
    
  • 相关阅读:
    Android Studio 字体和字号调整
    【IDEA】项目中引入Spring MVC
    【Double】double精度问题和int、long除不尽取舍问题
    【进制转换】原码反码和补码的理解以及进制转换
    【工具】SwitchHost的使用
    【工具】谷歌浏览器使用技巧
    【Git和GitHub】学习笔记
    【IE兼容性】代码中多语言样式+IE不兼容解决
    【Trello】使用指南
    【实操】进制转换:除基倒取余法
  • 原文地址:https://www.cnblogs.com/yushan1/p/11755503.html
Copyright © 2011-2022 走看看