WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在 WebSocket API 中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。
在 WebSocket API 中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。
现在,很多网站为了实现推送技术,所用的技术都是 Ajax 轮询。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。这种传统的模式带来很明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP请求可能包含较长的头部,其中真正有效的数据可能只是很小的一部分,显然这样会浪费很多的带宽等资源。
e.g 前端需要后台提供某个功能的得进度数据,并在页面显示 这时候我们可以使用websocket
function applyFileProgressDialogController(scope, $location, $mdDialog, $q, $websocket, ToolbarService) { scope.applyProgress = 0; scope.openWebSocket = function () { var wsUri = 'wss://' + $location.host() + ':' + $location.port() + '/ssc-common/translationNotification'; scope.ws = $websocket(wsUri); scope.ws.onOpen(function () { console.log("apply translation file web socket is opened ..."); }); scope.ws.onError(function (evt) { console.log("apply translation file web socket is error:"); console.log(evt); }); scope.ws.onClose(function (evt) { console.log("apply translation file web socket is closed!"); }); scope.ws.onMessage(function (message) { // var deferred = $q.defer(); var msgObject = JSON.parse(message.data); scope.applyProgress = msgObject["translationProgressBar"].toString().split('.')[0]; }); }; scope.openWebSocket(); scope.closeProgressDialog = function () { ToolbarService.logout(); // $mdDialog.cancel(); }; }