gpt4 book ai didi

javascript - 有没有办法子类化/继承/扩展 javascript WebSocket?

转载 作者:行者123 更新时间:2023-11-30 16:40:12 24 4
gpt4 key购买 nike

我到处都看了,似乎没有任何问题,更不用说关于这个的答案了。

我尝试了多种方法,使用原型(prototype)继承似乎是最好的方法

function MyWebSocket(url) {
// do other stuff
WebSocket.call(this, url);
}

MyWebSocket.prototype = Object.create(WebSocket.prototype);
MyWebSocket.prototype.constructor = MyWebSocket;
MyWebSocket.prototype.test = function () { alert('hi'); };

我可以单独分配测试函数就好了,但是在尝试覆盖构造函数时我得到错误“TypeError:无法构造'WebSocket':请使用'new'运算符,这个DOM对象构造函数不能被调用为来自 chrome 的函数”。

我知道这不是典型的 javascript 函数/对象,但我真的想要一种方法来覆盖 WebSocket 构造函数以启动其他维护函数,例如 ping 间隔,是的,我可以在 onopen 函数中单独执行此操作但这是我希望对站点上打开的所有 WebSocket 具有全局性的东西。

谢谢大家!

最佳答案

类似下面的内容可能对您有用:

function MyWebSocket(url) {
this.ws = new WebSocket(url);

}

MyWebSocket.prototype.test = (function() {
// this = MyWebSocket.ws, i.e. a plain WebSocket obj
}).bind(MyWebSocket.ws);

var myWS = new MyWebSocket(url);
myWS.test(); // does something to the underlying websocket

或者,要对底层 websocket 做一些事情,您不能使用 bind 而是在 MyWebSocket 上定义函数时仅引用 this.ws .原型(prototype)

关于javascript - 有没有办法子类化/继承/扩展 javascript WebSocket?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32123841/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com