会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132493个问题
JAVA 全系列/第十一阶段:分布式RPC调用和分布式文件存储/Dubbo 22861楼

老师你好,按照这个代码,箭头直线出不来是哪里出错了?

from tkinter import *
from tkinter.colorchooser import *

win_width = 900
win_height = 700


class Application(Frame):

    def __init__(self, master=None, bgcolor="#000000"):
        super().__init__(master)
        self.master = master
        self.bgcolor = bgcolor
        self.x = 0
        self.y = 0
        self.fgcolor = "#ff0000"
        self.lastDraw=0
        self.startDrawFlag=False
        self.pack()
        self.createWidget()

    def createWidget(self):
        self.drawpad = Canvas(root, width=win_width, height=win_height * 0.8, bg=self.bgcolor)
        self.drawpad.pack()

        # 创建按钮
        btn_start = Button(root, text="开始", name="start")
        btn_start.pack(side="left", padx="10")
        btn_pen = Button(root, text="画笔", name="pen")
        btn_pen.pack(side="left", padx="10")
        btn_rect = Button(root, text="矩形", name="rect")
        btn_rect.pack(side="left", padx="10")
        btn_clear = Button(root, text="清除", name="clear")
        btn_clear.pack(side="left", padx="10")
        btn_erasor = Button(root, text="橡皮擦", name="erasor")
        btn_erasor.pack(side="left", padx="10")
        btn_line = Button(root, text="直线", name="line")
        btn_line.pack(side="left", padx="10")
        btn_lineArror = Button(root, text="箭头直线", name="lineArror")
        btn_lineArror.pack(side="left", padx="10")
        btn_color = Button(root, text="颜色", name="color")
        btn_color.pack(side="left", padx="10")

        btn_pen.bind_class("Button", "<1>", self.eventManager)
        self.drawpad.bind("<ButtonRelease-1>",self.stopDraw)

    def eventManager(self, event):
        name = event.widget.winfo_name()
        print(name)
        if name == "line":
            self.drawpad.bind("<B1-Motion>", self.myline)
        elif name=="lineArrow":
            self.drawpad.bind("<B1-Motion>", self.mylineArrow)
        elif name == "rect":
            self.drawpad.bind("<B1-Motion>", self.myRect)

    def stopDraw(self,event):
        self.startDrawFlag=False
        self.lastDraw=0

    def startDraw(self,event):
        self.drawpad.delete(self.lastDraw)

        if not self.startDrawFlag:
            self.startDrawFlag = True
            self.x = event.x
            self.y = event.y

    def myline(self, event):
        self.startDraw(event)
        self.lastDraw=self.drawpad.create_line(self.x, self.y, event.x, event.y, fill=self.fgcolor)


    def mylineArrow(self,event):
        self.startDraw(event)
        self.lastDraw=self.drawpad.create_line(self.x, self.y, event.x, event.y,arrow=LAST, fill=self.fgcolor)

    def myRect(self,event):
        self.startDraw(event)
        self.lastDraw = self.drawpad.create_rectangle(self.x, self.y, event.x, event.y, outline=self.fgcolor)

if __name__ == '__main__':
    root = Tk()
    root.geometry(str(win_width) + "x" + str(win_height) + "+200+300")
    root.title("百战程序员的画图软件")
    app = Application(master=root)
    root.mainloop()


Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 22862楼
JAVA 全系列/第十一阶段:分布式RPC调用和分布式文件存储/Dubbo 22863楼

老师我在使用get 有参请求和post 请求时为什么打印不出来呢?

网上找到方法在php的开头加

ini_set("error_reporting","E_ALL & ~E_NOTICE");
发现打印的是  {12: "34", info: null}
为什么info 是Null
<!doctype html>
<html lang="us">
<head>
    <meta charset="utf-8">
    <title>jqajax</title>
    <script src="jquery-3.5.1.js"></script>
</head>
<style>
    button{
        padding:4px;
    }
</style>
<body>
<span>用户名:<input type="text"  class="usename" /> </span><br>
<span>密码:<input type="text"  class="password" /> </span><br>
<button>get无参</button>
<button>get有参</button>
<button>post请求</button>
<script>
var $name=$('.usename')
var $pass=$('.password')
var button= $('button')
//get 有参请求
button.eq(1).click(function () {
    $.ajax({
        //调用方式
        type: "GET",
        //发送的后台地址
        url: 'jqajax.php?username='+$name.val()+'&content='+$pass.val(),
        // data: {username:$name.val(), content:$pass.val()},
        //交互的数据格式
        dataType: "json",
        //当后台返回数据时,本函数自动执行,用来获取后台返回的具体数据内容
        success: function(res){
            console.log(res)
        }
    });
})
//post请求
button.eq(2).click(function () {
    $.ajax({
        //调用方式
        type: "post",
        //发送的后台地址
        url: 'jqajax.php',
        data: {username:$name.val(), content:$pass.val()},
        //交互的数据格式
        dataType: "json",
        //当后台返回数据时,本函数自动执行,用来获取后台返回的具体数据内容
        success: function(res){
            console.log(res)
        }
    });
})
</script>
</body>
</html>
<?php
 //get有参请求
   //$__GET//表示前端请求方式为get   并把前端传参带过来
      $arr=array('12'=>'34','info'=>$__GET);
   //通过echo 和 json_encode()方法将这个数据转换为json,并返回前端
       echo json_encode($arr);
 //$__POST//表示前端请求方式为post   并把前端传参带过来
       $arr=array('12'=>'34','info'=>$__POST);
  //通过echo 和 json_encode()方法将这个数据转换为json,并返回前端
                echo json_encode($arr);
  ?>


WEB前端全系列/第五阶段:前后端交互/PHP、数据库编程与设计 22864楼
JAVA 全系列/第九阶段:权限控制与安全认证/Shiro(旧) 22867楼
JAVA 全系列/第八阶段:Linux入门到实战/Git 22869楼
WEB前端全系列/第二阶段:JavaScript编程模块/Math与Date 22873楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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