javascript – ‘WebSocket.URL’已弃用.请改用’WebSocket.url’

WebSocket connection to 'ws://localhost:35729/livereload' Failed: Error in connection establishment: net::ERR_CONNECTION_REFUSED chromereload.js:9
'WebSocket.URL' is deprecated. Please use 'WebSocket.url' instead. chromereload.js:12

我在Chrome扩展程序中收到此错误消息,因为chrome更新到版本38.我不太清楚这里是什么,但现在打开大多数东西会导致扩展崩溃.我一开始就用自耕农来支撑我的项目,一切都很好.我尝试从清单中删除livereload,但这似乎打破了一切.任何帮助,将不胜感激.

这是代码

'use strict';

// Reload client for Chrome Apps & Extensions.
// The reload client has a compatibility with livereload.
// WARNING: only supports reload command.

var LIVERELOAD_HOST = 'localhost:';
var LIVERELOAD_PORT = 35729;
var connection = new WebSocket('ws://' + LIVERELOAD_HOST + LIVERELOAD_PORT + '/livereload');

connection.onerror = function (error) {
    console.log('reload connection got error' + JSON.stringify(error));
};

connection.onmessage = function (e) {
    if (e.data) {
        var data = JSON.parse(e.data);
        if (data && data.command === 'reload') {
            chrome.runtime.reload();
        }
    }
};

解决方法

在Chrome中,当在WebSocket对象上使用类似JSON.stringify()或类似内容的东西时会发出此消息.这些例程将访问不推荐使用的WebSocket.URL属性,并发出此警告.即使您的代码没有显式调用WebSocket.URL.您可以删除属性以将来自Chrome的警告静音.
var ws = new WebSocket('wss://example.com/');
delete ws.URL;
console.log(JSON.stringify(ws));

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...