javascript - “Uncaught SyntaxError: Unexpected token <”(但等等,还有更多!)
问题描述
我正在尝试学习如何使用 Websockets。我有一个名为 WebSocketClient.js 的文件,我正在尝试使用script
.jsp 文件中的标签导入该文件。这是JSP:
<!DOCTYPE html>
<html>
<head>
<title>Insert title here</title>
<link rel="stylesheet" href="css/styles.css">
</head>
<body>
<h4>${roomHost}'s room</h4>
<ul id="chat"></ul>
<form method="post" action="chat/${roomHost}" enctype="application/x-www-form-urlencoded">
<input type="text" name="message">
<input type="submit" value="Send">
</form>
<script type="text/javascript" src="js/WebSocketClient.js"></script>
</body>
</html>
当我在 Chrome 或 Firefox 中加载页面时出现错误Uncaught SyntaxError: Unexpected token <
,当我进入 DevTools 并查看 Sources 时,我看到它加载的 WebSocketClient.js 文件只是它正在的 .jsp 文件的副本加载自,请求属性roomHost
被替换为 javascript 文件的路径:
这太奇怪了,我以前从未经历过,我在互联网上找不到任何关于它的信息。怎么回事??
- 我尝试
<%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%>
在 JSP 顶部添加 - 我试过
<!doctype>
改变<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- 我试过
<!doctype>
完全删除 - 我已经尝试将
<script>
标签移动到<head>
- 我在
src
属性中尝试了不同的路径 - 我尝试将文件移动到不同的文件夹并从那里加载
- 我试过更改文件名
- 我尝试导入另一个 js 文件并且发生了同样的事情(加载的 js 文件的内容只是 .jsp 文件的副本)
我知道 js 文件不是问题,因为我可以从index.jsp
(而不是room.jsp
)很好地加载它。我以前开发过 Java Web 应用程序,但从来没有遇到过这个问题,我不知道是什么原因造成的。
解决方案
我弄清楚是什么原因造成的。该页面位于websockets-test/rooms/*
,因此它正在寻找 js 文件rooms/js/
而不是js/
webapp 文件夹中的目录。我将标签src
中的路径从更改为,现在它可以工作了。script
js/WebSocketClient.js
/websockets-test/js/WebSocketClient.js
推荐阅读
- php - 使用 javascript 更新视图而无需重复代码
- kubernetes - cluster-autoscaler 和 dns-controller 不断驱逐
- qt - QGraphicsSceneMouseEvent 获取位置不起作用
- kubernetes-helm - 多行 helm 值到 yaml 生成问题
- amazon-web-services - 使用对象标签删除存储桶中的对象
- r - 如何从多维数组到维护组的一维
- python - Django REST 框架 JSONParser().parse(request) 引发错误
- paypal - 抱歉,由于规定无法完成此付款
- python-3.x - 如何将 SAP .txt 提取转换为 .csv 文件
- javascript - 如何重用用于 node.js API 的 JS 文件