会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 133817个问题
Python 全系列/第二阶段:Python 深入与提高/文件处理 30286楼

老师,麻烦帮忙看一下我的代码:

源码:

作业_爬取拉钩职位.zip

运行结果中不能爬取到所有页面

image.png

另外保存的结果中有太多空格和\n

image.png

麻烦老师协助解决下,谢谢!





Python 全系列/第十六阶段:Python 爬虫开发/爬虫反反爬- 30287楼
JAVA 全系列/第二十二阶段:数字货币交易所项目/服务中台_后台管理系统的开发 30288楼
JAVA 全系列/第五阶段:网页编程和设计/Javascript 语言(旧) 30289楼
JAVA 全系列/第十二阶段:消息中间件与高并发处理/RocketMQ(旧) 30290楼
JAVA 全系列/第一阶段:AI驱动的JAVA编程/JAVA入门和背景知识 30291楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/智能电话本项目实战 30293楼
JAVA 全系列/第六阶段:项目管理与SSM框架/SpringMVC 30294楼
大数据全系列/第三阶段:Linux 操作系统/Linux操作系统概述与安装 30296楼

老师您好,浏览器获取对象信息显示空白,麻烦您看下代码是否有问题,谢谢!

2.png

package com.bjsxt.servlet;

import com.bjsxt.pojo.Users;
import com.fasterxml.jackson.databind.ObjectMapper;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.List;

/**
 * 通过JSON格式响应多个对象
 */
@WebServlet("/multiple.do")
public class MultipleObjectServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        Users users1 = new Users();
        users1.setUserid(1);
        users1.setUsername("OldLu");

        Users users2 =new Users();
        users2.setUserid(2);
        users2.setUsername("kevin");

        //需要将多个对象放入集合中
        List<Users> list = new ArrayList<>();
        list.add(users1);
        list.add(users2);

        //通过Jackson将List转换为JSON格式的字符串对象
        ObjectMapper objectMapper = new ObjectMapper();
        String string = objectMapper.writeValueAsString(list);
        System.out.println(string);
        resp.setContentType("application/json");
        PrintWriter pw = resp.getWriter();
        pw.println();
        pw.flush();
        pw.close();

    }
}
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
    <script>
        function but(){
            var xhr =new XMLHttpRequest();
            xhr.open("get","multiple.do");
            xhr.send();
            xhr.onreadystatechange =function (){
                if(xhr.readyState ==4 && xhr.status == 200){
                    alert(xhr.responseText);
                    //通过javaScript的内置对象JSON中的parse函数将JSON格式的字符串转换为javascript对象
                    var obj = JSON.parse(xhr.responseText);
                    var temp="";
                    for (i=0;i<obj.length;i++){
                        alert(obj[i].userid+" "+obj[i].username);
                        temp += obj[i].userid+" "+obj[i].username+"<br/>";
                    }

                    document.getElementById("span").innerHTML=temp;
                }
            }
        }
    </script>
</head>
<body>
<h3>JSON格式的多个对象响应</h3>
<hr/>
<span id="span"></span>
<input type="button" value="OK" onclick="but()"/>
</body>
</html>


JAVA 全系列/第六阶段:JavaWeb开发/Ajax技术详解(旧) 30298楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
  <style>
    *{
      margin: 0;
      padding: 0;
    }
    ul{
      background-color: #eaffea;
      list-style: none;
      font-size: 14px;
      width: 150px;
      display: block;
      position: relative;
      cursor: pointer;
      /*把鼠标变成小手*/
      display: none;
      z-index: 999;
    }
    li{
      padding-left: 20px;
      line-height: 25px;
    }
    li:hover{
      background-color: #fffdef;

    }
  </style>
</head>

<body>
<ul>
  <li>查看网页源代码</li>
  <li>刷新网页(F5)</li>
  <li>离开网页</li>
  <li>跳转到百度</li>
  <li>根据文本框内容搜索</li>
  <li>输入内容搜索</li>
</ul>
<div style="margin: 20px auto;width: 500px;position: relative">
  <span>搜索内容:</span><input type="text" style="width: 300px;">
</div>
<script>
  window.onload=function(){
    var ul=document.querySelector('ul');
    //系统右键菜单禁用事件【contextmenu】
    document.oncontextmenu = function (eve) {
      return false;
    };//return false表示事件禁用

    document.onmouseup=function (eve) {
      // console.log(eve.button);//查看鼠标哪个键被点击 左键0 滑轮1 右键2
      if (eve.button==2){
        ul.style.display='block';
        ul.style.left=event.clientX+'px';
        ul.style.top=event.clientY+'px';
      }else {
        ul.style.display='none';
      }
    }
    //事件委托
    ul.onmousedown=function (eve) {
      // console.log(eve.target.innerHTML);//根据这个来判断是哪一个li
      if (eve.button==2||eve.button==0){
        if (eve.target.innerHTML=='查看网页源代码'){
          alert('我不告诉你!!!');
          ul.style.display='none';
        } else if (eve.target.innerHTML=='刷新网页(F5)'){
          window.location.reload();
        } else if (eve.target.innerHTML=='离开网页'){
          var a=confirm('Do you sure 要离开网页?????');
          // console.log(a);
          if (a){
            window.close();
          } else {
            ul.style.display='none';
          }
        }else if (eve.target.innerHTML=='跳转到百度'){
          window.location.replace('http://www.baidu.com');
        }else if (eve.target.innerHTML=='根据文本框内容搜索'){
          var resukt=document.getSelection().toString();
          window.open('http://www.baidu.com/s?wd='+resukt);
        }
      }
    }
  }

</script>
</body>
</html>

老师,当点击鼠标右键的时候,ul的display属性取值为block或inline-block ,都会使得我本来设置的文本框向下移动;请问老师怎么设置能够使文本框在ul出现时依旧保持之前的位置

1602734274557592.png

image.png

WEB前端全系列/第二阶段:JavaScript编程模块/面向对象编程 30299楼
Python 全系列/第二阶段:Python 深入与提高/模块 30300楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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