C# 使用WebSocket与前端交互

<html>
<head>
</head>
<body>
	<a href="javascript:WebSocketTest()">运行 WebSocket</a>
	<a href=# onclick="send()">发送消息</a>
</div>

<script>
<!--在引用的页面 的最后 使用以下语句 开启 通信-->
<!--revieMsg 是逻辑处理的function -->
	_websocket.init(revieMsg,'');

	function send() {
		var val = "这是要发送的消息";
		<!--发送消息 调用下面的方法-->
		_websocket.send(val);
	}

	function revieMsg(msg) {
		console.log(msg);
	}
<!--在引用的页面 的最后 使用以下语句 开启 通信-->
</script>
</body>
</html>
<!--将下面的JS copy到一个单独的文件里,在需要的页面添加引用-->
<script type="text/javascript">
	let _websocket = {
		superWebsocket: false,
		isOpen: false,
		ws: null,
		callback: function (received_msg) {
			console.log(received_msg);
		},
		send: function (msg) {
			if (_websocket.superWebsocket && _websocket.isOpen) {
				_websocket.ws.send(msg);
			}
		},
		close: function () {
			_websocket.ws.close();
		},
		init: function (_callback,url,hellomsg) {
			var _url=url||"ws://127.0.0.1:4046";
			if ("WebSocket" in window) {
				_websocket.ws = new WebSocket(_url);

				_websocket.ws.onopen = function () {
					_websocket.isOpen = true;
					_websocket.superWebsocket = true;					
					if(hellomsg){
						//延时执行
						if(_websocket.ws.readyState == 0){
							_websocket.ws.send(hellomsg);
						}
						if(_websocket.ws.readyState == 1){
							setTimeout(function(){
								if(_websocket.ws.readyState == 0){
									_websocket.ws.send(hellomsg);
								}
								if(_websocket.ws.readyState == 1){
									setTimeout(function(){
										_websocket.ws.send(hellomsg);
									},1000);
								}
							},500);
						}
					}
				};

				_websocket.ws.onmessage = function (evt) {
					var received_msg = evt.data;				
					if (typeof (_callback) === "function") {
						_websocket.callback = _callback;
					}
					_websocket.callback(received_msg);
				};

				_websocket.ws.onclose = function () {
					_websocket.isOpen = false;
					console.log("closed");
				};
			}
		}
	};
</script>

比较容易遇到的一个问题就是上一个请求还在“通讯中”,下一个请求时会报错。这个时候就要延时处理

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值