记一次form标签引发的惨案

        最近在看WebSocket,于是自己动手搭了一个demo,前后台都搭建完了,连接没问题,断开连接也没有问题,但是就是发送信息时,连接会自动断开,这真是奇怪了,而且后台没有报任何错误!

        首先我还没只是认为是连接断开了,后来经过认真观察发现,不是连接断开,而是页面的刷新导致WebSocket连接断开,这就更奇怪了。

        当时的页面是这样子的:


        当时的页面代码是这样子的:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<link rel="stylesheet"
	href="https://cdn.bootcss.com/bootstrap/4.0.0-beta/css/bootstrap.min.css">
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
<script
	src="https://cdn.bootcss.com/bootstrap/4.0.0-beta/js/bootstrap.min.js"></script>
</head>
<body>
	<h3>WebSocket Test</h3>
	<div class="row">
		<div class="col-sm-3">
			<button id="connect_btn" class="btn btn-info">连接</button>
			<button id="colseConnBtn" class="btn btn-danger">关闭连接</button>
			<button id="testBtn" class="btn btn-default">测试按钮</button>
		</div>
		<div class="col-sm-3">
		</div>
	</div>
	<hr >
	<form class="row">
		<div class="col-sm-3">
			<input id="text" type="text" class="form-control" placeholder="请输入信息">
		</div>
		<div class="col-sm-1">
			<button id="sendBtn" class="btn btn-success" οnclick="send()">发送</button>
		</div>
	</form>
	<hr>
	<div>
		<ul class="list-group" id="message"></ul>
	</div>
</body>
<script type="text/javascript">
	var webSocket = null;

	$("#connect_btn").click(function() {
		if ('WebSocket' in window) {
			websocket = new WebSocket("ws://localhost:8080/websocket");
			
			$("#connect_btn").attr('disabled',true);
			
			//连接发生错误的回调方法
			websocket.onerror = function() {
				setMessageInnerHTML("与服务器连接失败...");
			};

			//连接成功建立的回调方法
			websocket.onopen = function(event) {
				setMessageInnerHTML("与服务器连接成功...");
			}

			//接收到消息的回调方法
			websocket.onmessage = function(event) {
				setMessageInnerHTML(event.data);
			}

			//连接关闭的回调方法
			websocket.onclose = function() {
				setMessageInnerHTML("已关闭当前链接");
			}

			//监听窗口关闭事件,当窗口关闭时,主动去关闭websocket连接,防止连接还没断开就关闭窗口,server端会抛异常。
			window.onbeforeunload = function() {
				websocket.close();
			}
		} else {
			alert("连接失败!当前浏览器不支持WebSocket!")
		}
	})
	
	$("#colseConnBtn").click(function(){
		closeWebSocket();
		$("#connect_btn").attr('disabled',false);
	})
	
    //将消息显示在网页上
    function setMessageInnerHTML(innerHTML) {
        $("#message").append("<li class=\"list-group-item\">" + innerHTML + "</li>");
    }

    //关闭连接
    function closeWebSocket() {
        websocket.close();
    }

    //发送消息
    function send() {
    	var message = $("#text").val()
        websocket.send(message);
    	//alert(message)
    }
    
    $("#testBtn").click(function(){
    	alert('testBtn')
    })
	
</script>

</html>

        我当时瞅了代码老半天,没毛病啊。怎么就出错了呢?后来写了一个测试按钮之后才发现,原来发送按钮是在form标签里面的,点击之后页面会自动刷新。把form标签改成div标签就可以了。不要问我为什么我会写成form标签,因为我刚开始想用form标签的form-horizontal,但是不雅观,然后就没改过去了。

        说这么多,总结起来就是一点,但是这点大家又常常会忘记,那就是:

        form标签里面的按钮,在点击之后页面会自动刷新!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值