JS面向对象的一种写法

封装的好处是代码重用,将变量保存和保护起来
如下例子(prototype方式):

let TF_SOCK = function (onopen, onmessage, onclose) {
    this.tf_sock = null;
    this.onopen = onopen;
    this.onmessage = onmessage;
    this.onclose = onclose;
}
TF_SOCK.prototype = {
    init_socket: function () {
        if ('WebSocket' in window) {
            let url = 'ws://' + window.location.host + '/websocket01';
            /**打开WebSocket*/
            this.tf_sock = new WebSocket(url);
            /**处理连接开启事件*/
            if (this.callable(this.onopen)) {
                this.tf_sock.onopen = this.onopen;
            }
            /**处理server发送来的消息*/
            this.tf_sock.onmessage = this.onmessage;
            /**处理连接关闭事件*/
            this.tf_sock.onclose = this.onclose;
        } else {
            alert("你的浏览器不支持WebSocket");
        }
    },
    send: function (msg) {
        this.tf_sock.send(msg);
    },
    callable: function (obj) {
        return typeof obj === "function"
    },
    destroy: function () {
        if (this.tf_sock) {
            this.tf_sock.close();
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值