登录  /  注册

javascript中接口是什么

青灯夜游
发布: 2021-10-27 18:02:52
原创
3404人浏览过

在javascript中,接口是指对协定进行定义的引用类型,接口其实就是告诉我们一个类实现了哪些方法,从而帮助其使用这个类;接口可以让代码变得更稳定。

javascript中接口是什么

本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

JavaScript中没有内置的创建或实现接口的方法。它也没有内置的方法用于判断该一个对象是否实现了与另一个对象相同的一套方法。这使对象很难互换使用。但是JavaScript很灵活,我们可以通过别的方式去实现。

什么是接口

接口其实就是定义了对象内应该有哪些方法。他不用去考虑这些方法是怎么去实现的,而是定义该对象有这些方法。

接口是指对协定进行定义的引用类型。其他类型实现接口,以保证它们支持某些操作。接口指定必须由类提供的成员或实现它的其他接口。与类相似,接口可以包含方法、属性、索引器和事件作为成员。

接口的好处

接口其实就是告诉我们一个类实现了哪些方法。从而帮助其使用这个类。接口可以让我们的代码变得更稳定,如果我们给接口添加了一个方法。而某个实现它的类没有相应的添加这个方法,那肯定会抛出一个错误。

javascript模仿接口

JavaScript模仿接口有三种方法:

  • 注释法

  • 属性检查法

  • 鸭式变型法

用注释描述接口

用注释描述接口是最简单的方法,但是效果是最差的。

/*
interface Composite {
    function add(child);
    function remove(child);
    function getChild(index);
}

interface FormItem {
    function save();
}
*/

class CompositeForm {
    add(child) {
        //...
    }
    remove(child) {

    }
    getChild(index) {
        //...
    }
    save() {
        //...
    }
}
登录后复制

这种模仿方法不是很好,它没有检查CompositeForm是否正确的实现了方法,完全是通过程序员们自觉去实现注释中的接口。不过这种实现方式非常的简单,但是它对测试和调试没有任何帮助。

属性检查法模仿接口

这个方法会更谨慎一点,但是接口也是注释的形式写出来,只是可以通过检查一个属性得知某个类自称实现了什么接口。

class CompositeForm {
    constructor() {
        this.implementsInterface = ['Composite', 'FormItem'];
    }
}

function addForm(formInstance) {
    if (!implements(formInstance, 'Composite', 'FormItem')) {
        throw new Error('对象没有实现接口方法');
    }
}

function implements(obj) { // 这个方法查询接口
    for (let i = 1; i <p>这种方法的优点是他对类所实现的接口提供了文档说明,如果需要的接口不在我这个类宣称支持的接口之列(也就是说不在我的this.implementsInterface里),你就会看到错误信息。</p><p>缺点也显而易见,如果我的this.implementsInterface里宣称的和我注释里所定义的接口不一样但检查还是能通过的,就是调用addForm方法是不会爆破错的</p><h3><strong>用鸭式变型法模拟接口</strong></h3><p>其实,类是否声明自己支持哪些接口并不重要,只要具有这些接口中的方法就行。鸭式变型法把对象的方法集作为判断它是不是某个实例的唯一标准。实现原理也非常的简单:如果对象具有与接口定义的方法同名的方法,那么就可以认为他实现了这个接口。</p><pre class="brush:php;toolbar:false">// interface
class Interface {
    constructor(name, method) {
        if (arguments.length != 2) {
            throw new Error('两个参数:name method');
        }
        this.name = name;
        this.method = [];
        for (let i in method) {
            if (typeof method[i] != 'string') {
                throw new Error('method 必须是字符串');
            }
            this.method.push(method[i]);
        }
    }
    //检查接口方法
    static ensureImplements(obj) {
        if (arguments.length <p>上面代码中的CompositeForm类中我没有实现save方法。运行这段代码就会报错。</p><p>但是鸭式变型法也是有缺点的,各个检查方面都是强制实施的。</p><h3><strong>本菜鸟实现方法 &gt; 我自称继承法</strong></h3><p>我用了类的继承来模拟接口,具体实现请看代码。</p><p>首先我们定义一个用作接口的类,属性method代表接口的方法集</p><pre class="brush:php;toolbar:false">class Interface {
    constructor() {
        this.mehods = ['add', 'save', 'remove', 'save'];
    }
    static ensureImplements(obj) {
        //...
    }
}
登录后复制

定义一个CompositeForm类继承这个接口,并且在该类里面调用父类的ensureImplements方法检测接口

class CompositeForm  extends Interface{
    constructor() {
        super().ensureImplements(this);
    }
}
登录后复制

完善ensureImplements方法

class Interface {
    constructor() {
        this.mehods = ['add', 'save', 'remove', 'save'];
    }
    static ensureImplements(obj) {
        for (let i in this.mehods) {
            let methodName = this.mehods[i]
            if (!obj[methodName] || typeof obj[methodName] !== 'function') {
                let err = '请实现接口' + methodName + '的方法';
                throw new Error(err);
            }
        }
    }
}
登录后复制

【推荐学习:javascript高级教程

以上就是javascript中接口是什么的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号