会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132904个问题

老师,在自己做的HTML中输入java之后出现的URL地址是

https://www.baidu.com/s?word=java&tn=95834041_hao_pg

而不是wd=java

这是怎么一回事呢?(操作,代码和老师都是一样的)





JAVA 全系列/第四阶段:网页编程和设计/HTML5(旧) 30601楼

老师您好,为什么在django的shell界面中测试时,执行serializer.save()之前需要先执行serializer.validated_data,否则会报错,但是在views.py中,在serializer.save()之前未加上serializer.validated_data,却不会报错?


项目根目录下输入python manage.py shell后,执行如下代码:

# 将 json格式的字节串 转换为字典
from rest_framework.parsers import JSONParser
stream = io.BytesIO(b'{"name":"rose", "age":19, "sex":2}') #这里如果把单引号和双引号交换,执行JSONParser().parse(stream)时会报错rest_framework.exceptions.ParseError: JSON parse error - Expecting property name enclosed in double quotes
# 得到字典数据, {'id': 1,......}
data_dict = JSONParser().parse(stream)

# 将字典数据 反序列化
serializer = StudentSerializer(data=data_dict)
# 必须执行这一步验证, 返回True才可以获取后续的 validated_data数据和执行 save等方法
serializer.is_valid()
# 得到 OrderedDict([('name', 'terry'),......] , 会忽略掉 id 属性
serializer.validated_data
# 保存到数据库中
serializer.save()

django项目的views.py中:

@csrf_exempt
def students(request):
    if request.method == 'GET':
        student_li = Student.objects.all()
        serializer = StudentSerializer(student_li, many=True)
        return JsonResponse(serializer.data, safe=False)

    elif request.method == 'POST':
        data = JSONParser().parse(request)
        serializer = StudentSerializer(data=data)
        if serializer.is_valid():
            serializer.save()
            return JsonResponse(serializer.data, status=201)
        return JsonResponse(serializer.errors, status=400)


Python 全系列/第十二阶段:Python_Django3框架/Django高级 30602楼

分享:ModuleNotFoundError: No module named 'django.utils.six'的解决办法,参考:https://blog.csdn.net/zhch1979/article/details/104684122/

问题分析:python3.8.3+Django3.0.7环境下用富文本编辑DjangoUEditor,DjangoUEditor中关于six的引用会报错,原因是Django3.0.7移除了six。

解决办法:

  1. 单独安装six:pip install six。另外,urllib 好像也独立出来了,引用时不需有前缀。

  1. 安装完six之后,将DjangoUEditor中有关的引用路径修改一下。包括如下四个文件的修改。

(1)DjangoUEditor目录下的views.py文件中有如下行

from django.utils import six
from django.utils.six.moves.urllib.request import urlopen
from django.utils.six.moves.urllib.parse import urljoin

改为:

import six
from six.moves.urllib.request import urlopen
from six.moves.urllib.parse import urljoin

(2)widgets.py文件中有如下一行:

from django.utils.six import string_types

修改为:

from six import string_types

(3)urllib似乎已从six之中独立出来,故commands.py文件中的如下一行:

from django.utils.six.moves.urllib.parse import urljoin

改为:

from urllib.parse import urljoin

(4)utils.py中有如下一行:

from django.utils import six

改为:

import six

以上四个文件中对six的引用路径修改后,Django3项目进入后台,富文本编辑能正常使用。


Python 全系列/第十二阶段:Python_Django3框架/Django高级 30604楼
Python 全系列/第十一阶段:重量级Web框架-Django/Redis的入门与应用(拓展) 30605楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/IO 流技术(旧) 30606楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/智能电话本项目实战 30609楼
Python 全系列/第一阶段:Python入门/Python入门(动画版) 30612楼

QQ图片20220509080830.jpg

Python 全系列/第二阶段:Python 深入与提高/游戏开发-坦克大战 30613楼

老师好,控制提示框移动范围时,使用“if else”可以实现,但使用“switch”时没有效果。

应该是我的switch语句没写对(第35行代码),怎么写才正确?求指导,谢谢。

<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>鼠标事件</title>
<style>
    input{
        width: 300px;
        margin: 100px 600px 0px;
    }
    #tips{
        width: 30px;
        height: 25px;
        margin: 0px 750px;
        padding: 0;
        font-size: 18px;
        text-align: center;
        border: 1px solid aqua;
        position: absolute;
        display: none;
    }
</style>
</head>
<body>
    <input type="range" min="0" max="100" value="50">
    <div id="tips"></div>
<script>
    var input=document.querySelector('input');
    var tips=document.getElementById('tips');
    function move(){
        input.onmousemove=function () {
            var x=event.clientX;
            var Y=event.clientY;
            // 使用switch语句控制提示框移动范围????????????????????????????????????????
/*            switch (x) {
                case x<600:tips.style.left=-150+'px';
                    break;
                case x>900:tips.style.left=150+'px';
                    break;
                case x>=600&&x<=900:tips.style.left=(x-750)+'px';
                    break;
            }*/
            // 使用if语句控制提示框移动范围
            if (event.clientX>900){
                x = 900;
            }else if (event.clientX<600){
                x = 600;
            }else{
                tips.style.left=(x-750)+'px';
            }

            tips.innerHTML=input.value;

            // console.log('(x,y):('+x+','+'y'+')');
        }
    };
    input.onmousedown=function () {
        tips.style.display='block'
        move();
    };
    input.onmouseup=function () {
        tips.style.display='none'
        input.onmousemove=null;
    }
</script>
</body>
</html>


WEB前端全系列/第二阶段:JavaScript编程模块/浏览器模型(BOM) 30614楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637