码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 前端 TS 快速入门之二:接口


    1. 接口有什么用

    interface 定义接口。

    检测对象的属性,属性的顺序不检测,只检测属性是否存在,属性类型是否和接口一致。

    1. interface IPerson {
    2. name: string;
    3. age: number;
    4. }
    5. function say(person: IPerson): void {
    6. console.log(`my name is ${person.name}, and age is ${person.age}`);
    7. }
    8. let me = {
    9. name: "funlee",
    10. age: 18,
    11. };
    12. say(me); // my name is funlee, and age is 18

    2. 可选属性

    属性后加 ? 符号,表示可选。

    1. interface IPerson {
    2. name: string;
    3. age: number;
    4. // love 可选
    5. love?: string;
    6. }

    3. 只读属性

    属性前加 readonly,表示只读。

    1. interface IPerson {
    2. // name 只读
    3. readonly name: string;
    4. age: number;
    5. love?: string;
    6. }
    7. let me: IPerson = {
    8. name: "funlee",
    9. age: 18,
    10. };
    11. // name 不允许被赋值
    12. me.name = "new name"; // error!

    4. 函数接口

    定义函数的参数和返回值类型

    1. interface IGetArea {
    2. (w: number, h: number): number;
    3. }
    4. const getArea: IGetArea = (w, h) => {
    5. return w * h;
    6. };
    7. getArea(10, 20) // 200

     5. 继承接口

    一个接口可以继承多个接口,创建出多个接口的合成接口,如:

    1. interface IName {
    2. name: string;
    3. }
    4. interface IAge {
    5. age: number;
    6. }
    7. interface IPerson extends IName, IAge {
    8. sex: string;
    9. }
    10. const yqcoder: IPerson = {
    11. name: "yqcoder",
    12. age: 18,
    13. sex: "man",
    14. }; // { name: 'yqcoder', age: 18, sex: 'man' }

     6. 混合类型

    让对象同时作为函数和对象使用,并带有额外的属性,如:

    1. interface IMixDemo {
    2. (arg: string): void;
    3. defaultStr: string;
    4. }
    5. function demo(): IMixDemo {
    6. let x = <IMixDemo>function (str: string) {
    7. console.log(str);
    8. };
    9. x.defaultStr = "yqcoder";
    10. return x;
    11. }
    12. const yq = demo(); // { [Function: x] defaultStr: 'yqcoder' }
    13. yq('你好'); // 你好

    上一章:前端 TS 快速入门之一:基本数据类型

    下一章:前端 TS 快速入门之三:class 类

  • 相关阅读:
    Acrobat Pro DC 2021:强大的PDF编辑软件
    自己动手从零写桌面操作系统GrapeOS系列教程——13.向MBR中写入程序
    vivo霍金实验平台设计与实践-平台产品系列02
    MySQL json相关函数详解
    从另外一个进程中读取数据
    LeetCode简单题之最好的扑克手牌
    超声波清洗机靠谱吗?实用性比较高的超声波清洗机推荐
    Hadoop 集群时间同步设置
    八大排序java
    找工作
  • 原文地址:https://blog.csdn.net/weixin_64684095/article/details/133963575
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号