会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132469个问题
Python 全系列/第一阶段:Python入门/编程基本概念 30811楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Maven 30812楼
JAVA 全系列/第三阶段:数据库编程/MySQL数据库的使用 30813楼
JAVA 全系列/第一阶段:JAVA 快速入门/面向对象详解和JVM底层内存分析 30815楼

from tkinter import *  # 导入tkinter里得全部方法
from tkinter import messagebox  # 调用 messaagebox 模块
import random


class Application(Frame):
    def __init__(self,master=None):
        super().__init__(master) #super代表父类定义 而不是父类对象
        self.master=master
        self.pack()
        self.createWidget()

    def createWidget(self):  # 创建组件
        """通过place布局管理实现扑克牌位置控制"""
        self.photos = [PhotoImage(file="venv/11"+str(i+1)+".gif") for i in range(10)]
        self.pukes = [Label(self.master,image=self.photos[i])for i in range(10)]
        for i in range(10):
            self.pukes[i].place(x=10+i*40,y=50)
        self.pukes[0].bind_class("Label","<Button-1>",self.chupai)
    def chupai(self,event):
        print(event.widget.winfo_geometry())
        print(event.widget.winfo_y())
        if event.widget.winfo_y == 50:
            event.widget.place(y=30)
        else:
            event.widget.place(y=50)





if __name__ == '__main__':
    root=Tk()
    root.geometry('800x400+200+300')
    root.title('扑克游戏界面')
    app=Application(master=root)
    root.mainloop()

a23423ffc97e66344a06ebfc7472f6c.png


老师 我这里那些错了吗? 单机牌后 它不动 单机多次坐标都不动 else 中 换成30 单机后 出牌了 却回不来了  帮我看一下咋回事

Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 30816楼

$(function(){
    //个人定制开始,规定一个页面只能加载15条数据
    var numPerPage = 15;
    //先要获取一共多少数据,向后台发送请求
    $.get('resource/yz_paginationTool/paginationTool.php',{},function(res){
        var totalLength =JSON.parse(res).dataLength;
        console.log(totalLength);
        var pageCount = Math.ceil(totalLength/numPerPage);//得到页数,然后动态增加分页器
        inserHtml(pageCount,1);
        bindEvent(pageCount);
        //当页面绘制完成后,加载第一页的数据
        getData(1);
    });
    // 默认测试
    /* var pageCount=15;
     inserHtml(pageCount,1);
     bindEvent(pageCount);*/

    /*
        绘制页面的
        page表示一共有多少页
        current默认加载第几页
    */
    function inserHtml(page,current){
        console.log('page:'+page+'-----current:'+current)
        var obj = $(".ts-page");
        obj.empty();
        if(current > 1){
            obj.append('<span class="tspage-start">首页</span>');
            obj.append('<span class="tspage-before">上一页</span>');
        }else{
            obj.remove('.tspage-start');
            obj.append('<span class="tspage-before disable">上一页</span>');
        }
        if(current>3 && current <= page && page>5){
            obj.append('<span class="tspage-ell">...</span>');
        }
        var start = current-2, end= current+2; //中间显示5个
        if(start >1 && current < 4||current == 1){
            end++; //前面会没有省略号。
        }
        if(current > page-2 && current <= page){
            start--; //后面的省略号消失
        }
        for(;start<=end;start++){
            if(start<=page && start >=1){
                if(start != current){
                    obj.append('<span class="page">'+start+'</span>');
                }else{
                    obj.append('<span class="page on">'+start+'</span>');
                }
            }
        }
        if(current+2<page && current >=1 && page>4){
            obj.append('<span class="tspage-ell">...</span>');
        }
        if(current<page){
            obj.append('<span class="tspage-after">下一页</span>');
            obj.append('<span class="tspage-end">尾页</span>');
        }else{
            obj.remove('.tspage-end');
            obj.append('<span class="tspage-after disable">下一页</span>');
        }
    }
    /*
        给分页器工具绑定事件监听
        page表示需要给多少个页面添加事件监听
    */
    function bindEvent(page){
        var obj = $(".ts-page");
        obj.on('click','.page',function(){
            var currentPage = parseInt($(this).text());
            inserHtml(currentPage,page);
            inserHtml(page,currentPage);
            //接下来就是获取后台传来数据的ajax函数+数据适配
            getData(currentPage);
        });
        obj.on('click','.tspage-before',function(){
            var currentPage = parseInt(obj.children('.on').text());
            if(currentPage>1){
                inserHtml(page,currentPage-1);
                //接下来就是获取后台传来数据的ajax函数+数据适配
                getData(currentPage-1);
            }

        });
        obj.on('click','.tspage-after',function(){
            var currentPage = parseInt(obj.children('.on').text());
            if(currentPage<page){
                inserHtml(page,currentPage+1);
                //接下来就是获取后台传来数据的ajax函数+数据适配
                getData(currentPage+1);
            }
        });
        obj.on('click','.tspage-start',function(){
            inserHtml(page,1);
            //接下来就是获取后台传来数据的ajax函数+数据适配
            getData(1);
        });
        obj.on('click','.tspage-end',function(){
            inserHtml(page,page);
            //接下来就是获取后台传来数据的ajax函数+数据适配
            getData(page);
        });
    }

    // 根据选择的页码数处理数据
    function getData(num){
        console.log('num:'+num);
       $.get('resource/yz_paginationTool/paginationTool.php?page='+num, function(data){
           var allDataArr=JSON.parse(data).list;
            //根据数据,将元素创建到页面中
           var  outDiv=document.querySelector('.out');
           if(!outDiv){
              //如果没有outDiv,创建一个
               outDiv=document.createElement('div');
               outDiv.className='out';
               outDiv.style.cssText='position:relative;margin:0 auto; ';
               document.body.appendChild(outDiv);
               //根据数据,创建inDivs
               for(var i=0;i<allDataArr.length;i++){
                   var inDivs=document.createElement('div');
                   inDivs.className='in';
                   inDivs.style.cssText='float:left;width:280px;border:1px  solid black;margin:10px ;' ;
                    //添加内容
                   var neirongStr="<img  src='"+allDataArr[i].headimgurl+"'>"+"<span  class='ts-cardname' style='vertical-align: top'>"+"<p>"+allDataArr[i].sectiontitle+"</p>"+
                   "<em  style='vertical-align: bottom'>"+allDataArr[i].sectionauthor+"</em>"+"</span>";
                   //添加标签
                   neirongStr=neirongStr.concat("<i class='chat-tag'>"+allDataArr[i].sectiontype+"</i>");
                  //添加文本
                   neirongStr=neirongStr.concat("<p class='chat-content'>"+allDataArr[i].sectioncontent+'</p>');
                //    console.log(neirongStr);

                   inDivs.innerHTML=neirongStr;
                   outDiv.appendChild(inDivs);
               }
           }else{
               //清空页面
            //    outDiv.innerHTML='';
              var inDivs=document.createElement('div');
              inDivs.className='in';
              inDivs.style.cssText='float:left;width:280px;height:250px;border:1px  solid black;margin:10px ;' ;
               //添加内容
              var neirongStr="<img  src='"+allDataArr[i].headimgurl+"'>"+"<span  class='ts-cardname' style='vertical-align: top'>"+"<p>"+allDataArr[i].sectiontitle+"</p>"+
              "<em  style='vertical-align: bottom'>"+allDataArr[i].sectionauthor+"</em>"+"</span>";
              //添加标签
              neirongStr=neirongStr.concat("<i class='chat-tag'>"+allDataArr[i].sectiontype+"</i>");
             //添加文本
              neirongStr=neirongStr.concat("<p class='chat-content'>"+allDataArr[i].sectioncontent+'</p>');
              console.log(neirongStr);
              inDivs.innerHTML=neirongStr;
              outDiv.appendChild(inDivs);
            
           }

           

       });
       cardWaterfall();
      
    }
    // //页面加载完成后瀑布流
    function cardWaterfall(){
        var cardArr=$('.in');
        console.log(cardArr.length);
        //此处结果为0
       }
    
});

最后这句不管在哪跑结果都是0

console.log(cardArr.length);

脑袋都想破了没想到哪里出的问题,我新建了js,用window.onload在浏览器结束运行后去查,也不行,我js里构建的class都查不到,但是在浏览器里可以查到

image.png

老师,你本地试试看,能不能查出这节课里面的.in   这个div

WEB前端全系列/第六阶段:音乐社区高级项目模块/移动端:基于jQuery使用Ajax和BootStrap 30818楼
JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解 30819楼
JAVA 全系列/第一阶段:JAVA 快速入门/面向对象详解和JVM底层内存分析 30821楼
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 30823楼

老师,我照着视频敲的,这个怎么解决?

image.png

源码

package com.bjsxt.server;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

import java.io.File;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class WebDom4j { //用于解析XML
    private List<Entity> entityList; //用于存储N多Entity,而每一个Entity都是servlet-name和servlet-class
    private List<Mapping> mappingList; //用于存储N多Mapping,而每一个Mapping都是一个servlet-name和N多个url-pattern

    public List<Entity> getEntityList() {
        return entityList;
    }

    public void setEntityList(List<Entity> entityList) {
        this.entityList = entityList;
    }

    public List<Mapping> getMappingList() {
        return mappingList;
    }

    public void setMappingList(List<Mapping> mappingList) {
        this.mappingList = mappingList;
    }

    public WebDom4j() {
        entityList = new ArrayList<Entity>();
        mappingList = new ArrayList<Mapping>();
    }
    public Document getDocument(){
        try {
            //(1)创建SAXReader对象
            SAXReader reader = new SAXReader();
            //(1)调用reader方法
            return reader.read(new File("D:\\MyCode\\IdeaProjects\\firstPreject\\http_server2\\src\\WEB_INFO\\web.xml"));
        } catch (DocumentException e) {
            e.printStackTrace();
        }
        return null;
    }
    public void parse(Document doc){
        //获取根元素
        Element root = doc.getRootElement(); //web-app
        //获取servlet子元素
        for (Iterator<Element> ite =  root.elementIterator("servlet");ite.hasNext();){
            Element subElement = ite.next(); //得到每一个servlet
            //创建一个实体类Entity
            Entity ent = new Entity(); //用于存储servlet-name和servlet-class
            for (Iterator<Element> subIte = subElement.elementIterator();subIte.hasNext();){
                Element ele = subIte.next(); //可能是servlet-name,也可能是servlet-class
                if ("servlet-name".equals(ele.getName())){
                    ent.setName(ele.getText()); //给实体类中的name赋值
                }else if ("servlet-class".equals(ele.getName())){
                    ent.setClazz(ele.getText()); //给实体类中的clazz赋值
                }
                //将Entity添加到集合中
                entityList.add(ent);
                for (Entity entity: entityList
                     ) {
                    System.out.println(entity.getName() + "\t" +entity.getClazz());
                }
            }
        }
    }
    //测试
    public static void main(String[] args) {
        WebDom4j web = new WebDom4j();
        web.parse(web.getDocument());
    }
}

image.png

JAVA 全系列/第二阶段:JAVA 基础深化和提高/手写服务器项目(旧) 30824楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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