为什么报错,和视频代码一样呀

为什么报错,和视频代码一样呀

<script type="text/javascript">
		//1.创建XmlHttpRequest
		var XmlHttp;
		if(window.XMLHttpRequest){
			xmlHttp=new XMLHttpRequest();
		}else{
			xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
		}
		//2.发送Ajax请求
		xmlHttp.open("GET","/demo_ajax/firstServlet",true);
		xmlHttp.send();
		//3.处理服务器请求
		xmlHttp.onreadystatechange=function(){
			if(xmlHttp.readyState == 4 && xmlHttp.status == 200){
				var text = xmlHttp.responseText;
				console.log(text);
				var json=JSON.parse(text);
				console.log(json);
			}
		}
	</script>

http://img1.sycdn.imooc.com//climg/5e956ebc0956311607950243.jpg

正在回答

登陆购买课程后可参与讨论,去登陆

3回答

同学你好,同学运行报错是因为FirstServlet类中,如下图:代码有错

http://img1.sycdn.imooc.com/climg/5e9592dc0958695311060246.jpg

修改建议:建议同学将本行代码删除,json对象转换格式如同学的拼接方式是不正确的,不建议自己在后台拼接信息。

删除后代码可正常运行。运行效果如下:

http://img1.sycdn.imooc.com/climg/5e9592e409a0bf7e11060188.jpg

关于代码规范,类名首字母大写,同学要注意修改。

如果我的回答解决了你的疑惑,请采纳,祝学习愉快~

提问者 weixin_慕设计9597346 2020-04-14 17:49:11
package com.imooc.demo;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

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 com.alibaba.fastjson.JSON;

/**
 * Servlet implementation class firstServlet
 */
@WebServlet("/firstServlet")
public class firstServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public firstServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

	/**
	 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		List list=new ArrayList();
		list.add(new Employee("小红","经理","人事部"));
		list.add(new Employee("小明","职员","技术部"));
		list.add(new Employee("小白","经理","无线事业部"));
		String json=JSON.toJSONString(list);
		System.out.println(json);
		response.setContentType("text/html;charset=UTF-8");
		response.getWriter().println(json);
		response.getWriter().append("Served at: ").append(request.getContextPath());
	}


}
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<style type="text/css">
input{
	width:30%;
}
</style>
<title>Insert title here</title>
</head>
<body>
	<input type="button" value="员工列表">
	<input type="button" value="职位列表">
	<input type="button" value="部门列表">
	<script type="text/javascript">
		//1.创建XmlHttpRequest
		var XmlHttp;
		if(window.XMLHttpRequest){
			xmlHttp=new XMLHttpRequest();
		}else{
			xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
		}
		//2.发送Ajax请求
		xmlHttp.open("GET","/demo_ajax/firstServlet",true);
		xmlHttp.send();
		//3.处理服务器请求
		xmlHttp.onreadystatechange=function(){
			if(xmlHttp.readyState == 4 && xmlHttp.status == 200){
				var text = xmlHttp.responseText;
				console.log(text);
				var json=JSON.parse(text);
				console.log(json);
			}
		}
	</script>
</body>
</html>


好帮手慕小琪 2020-04-14 17:29:41

同学你好,老师只能看到部分代码,猜测是同学的index.html中的发送ajax请求时xmlHttp.open()方法中发送的地址有错。

修改建议:如果同学代码与视频中老师代码相同,xmlHttp.open()方法中发送的地址应为同学的项目名+视频中NewsListServlet类中@WebServlet("/news_list")的括号中双引号中的内容。

例如同学项目名为:demo_ajax,那么xmlHttp.open()方法应为:xmlHttp.open("GET","/demo_ajax/news_list",true);

运行代码如下:

http://img1.sycdn.imooc.com//climg/5e9582700942270a07440142.jpg

如果没有解决同学的问题,建议同学将相关联的全部代码都粘贴到问答区,方便老师测试同学的代码。

如果我的回答解决了你的疑惑,请采纳,祝学习愉快~

  • 如果xmlHttp.open()方法中发送的地址有错,那我截图中的console.log(text)也不会显示出来呀!?
    2020-04-14 17:56:19
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
意见反馈 帮助中心 APP下载
官方微信

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师