草庐IT

interface接口

泡杯感冒灵 2023-03-28 原文
先声明2个普通函数,
// 这两个函数在没有用TS的情况下,语法其实是有问题的,假如person传进来的是undefined,那么整个语句运行时就会报错。
const getPersonName = (person) => {
  console.log(person.name);
}

const setPersonName = (person,name) => {
  person.name = name;
}
为了避免错误,我们需要给person一个类型注解
const getPersonName = (person:{name:string}) => {
  console.log(person.name);
}

const setPersonName = (person:{name:string},name:string) => {
  person.name = name;
}
有通用型的一些类型的集合,我们可以把他用interface表示出来
interface Person {
  name: string;
}

const getPersonName = (person: Person) => {
  console.log(person.name);
}

const setPersonName = (person: Person,name:string) => {
  person.name = name;
}
同样,我们也可以用类型别名来表示

type Person1 =  {
  name: string;
}

const getPersonName = (person: Person1) => {
  console.log(person.name);
}

const setPersonName = (person: Person1,name:string) => {
  person.name = name;
}
interface(接口)和type(类型别名)的区别
  • interface 只能代表一个函数或者对象,没法直接代表一个基础类型
  • type可以直接代表一个基础类型
type Person1 = string;
  • TS中,通用的规范是如果能用接口来表示一些类型的话,就用接口,实在不行,再用类型别名。
当我们定义一个接口时,会遇到一种情况,就是参数的有些属性是可有可无的。这个时候,我们该怎么定义interface呢?属性后边跟问号
// 假如age是可有可无的,这个时候我们这样定义,那么传的参数类型,就必须要有age属性,否则就报错。
interface Person {
  name: string;
  age: number;
}

const person = {
  name:'mike'
}

getPersonName(person);

// 这个时候,就需要这样定义interface
interface Person {
  name: string;
  // age加个问号,表示这个属性,可有可无
  age?: number;
}
只读属性
interface Person {
  readonly name: string;
  age?: number;
}

// 接口里,name属性是只读的,所以当我尝试改变name值的时候,就会报错
const setPersonName = (person: Person,name:string):void => {
  person.name = name;
}
接口里必须要有的属性,传的时候,一定要有,否则就报错,如果接口里没有定义,但是却传了,也不会报错。
// Person接口规定,参数必须要有name属性,age属性可有可无。
interface Person {
  name: string;
  age?: number;
}

const getPersonName = (person: Person):void => {
  console.log(person.name);
}

// sex属性接口没有定义,也不会报错。因为Person类型要求必须要有name属性。是匹配的上的。
const person = {
  name: 'mike',
  sex:'male'
}

getPersonName(person);
但是,如果把person 这个对象字面量,直接写在方法后面,就会报错
interface Person {
  name: string;
  age?: number;
}

const person = {
  name: 'mike',
  sex:'male'
}

getPersonName({
  name: 'mike',
  sex:'male'
});
image.png
  • 为什么传person变量不报错,而直接传对象字面量的形式传递就会报错呢?主要是因为TS会对字面量的形式进行强校验,接口定义的时候,只有name属性和一个可有可无的age属性,不能再有其他属性。而字面量多了sex属性,所以报错。
如果接口Person,除了name和age属性之外,还可能有其他属性,但是属性的名字不确定,属性的值的类型也不确定,该怎么定义呢?
// [propName: string]: any;的意思是,Person 多出其他的属性名字是一个字符串,值的类型是任意类型。
interface Person {
  name: string;
  age?: number;
  [propName: string]: any;
}
  • 这个时候,我们再通过字面量的形式传sex属性,就不会报错了


    image.png
接口不仅仅可以存属性和它对应的类型,还可以存方法
// 意思是接口Person 不单单有属性,还有say方法,方法的返回值是个字符串。
interface Person {
  name: string;
  age?: number;
  [propName: string]: any;
  say(): string;
}
  • 这个时候,就需要在参数里加上这个say方法,否则就会报错


    image.png
  • 我们给参数加了方法,并且方法有返回值,再传就不会报错了
const person = {
  name: 'mike',
  sex: 'male',
  say() {
    return 'say hello'
  }
}

getPersonName(person);
setPersonName(person,'lee');
class 类这个概念,TS,ES6,都有类这个概念,类实际上是可以应用接口的。
// 意思是User这个类,应用Person这个接口;
class User implements Person {}
  • 类应用接口的时候,必须要有接口里的这些属性和方法,否则就会报错
class User implements Person {
  name = 'LEE';
  say() {
    return 'hello'
  }
}
接口还可以互相继承
interface Person {
  name: string;
  age?: number;
  [propName: string]: any;
  say(): string;
}

// 接口Teacher  继承了 接口Person 
// 意味着,如果参数被类型注解为Teacher接口后,不单要有Person 接口的属性和方法,还要有Teacher接口的属性和方法。否则会报错
interface Teacher extends Person {
  teach(): string;
}

const setPersonName = (person: Teacher,name:string):void => {
  person.name = name;
}

const person = {
  name: 'mike',
  sex: 'male',
  say() {
    return 'say hello'
  },
  teach() {
    return 'hello'
  }
}
setPersonName(person, 'lee');
接口除了定义这些属性和方法之外,还可以定义一个函数的类型。
// 这里是定义一个函数的类型声明,函数类型是SayHi 
// 函数必须要接收一个string类型的参数,返回值也是string类型。
interface SayHi {
  (word:string):string
}

// 用一下这个接口
const say:SayHi = (word:string) => {
  return word;
}
interface接口,在ts编译为js后会是什么样的呢?
  • 首先运行命令 tsc --init ,这个命令会把工程初始化为一个TS工程,里边会多一个tsconfig.json这样的文件。里边会有一些配置
  • 运行 tsc demo.ts命令,编译demo.ts为demo.js
var getPersonName = function (person) {
    console.log(person.name);
};
var setPersonName = function (person, name) {
    person.name = name;
};
var person = {
    name: 'mike',
    sex: 'male',
    say: function () {
        return 'say hello';
    },
    teach: function () {
        return 'hello';
    }
};
getPersonName(person);
setPersonName(person, 'lee');
var User = /** @class */ (function () {
    function User() {
        this.name = 'LEE';
    }
    User.prototype.say = function () {
        return 'hello';
    };
    return User;
}());
var say = function (word) {
    return word;
};
接口实际上,就是我们开发过程中,TS帮我们做语法提示校验的工具,真正编译成JS代码的时候,TS会把 interface 包括 type 的内容,全部剔除掉。

有关interface接口的更多相关文章

  1. postman接口测试工具-基础使用教程 - 2

    1.postman介绍Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。2.下载安装官网地址:https://www.postman.com/下载完成后双击安装吧,安装过程极其简单,无需任何操作3.使用教程这里以百度为例,工具使用简单,填写URL地址即可发送请求,在下方查看响应结果和响应状态码常用方法都有支持请求方法:getpostputdeleteGet、Post、Put与Delete的作用get:请求方法一般是用于数据查询,

  2. ruby-on-rails - 如何在 RubyOnRails 中使用 'acts as nested set' 创建一个可排序的接口(interface) - 2

    我一直在为使用acts_as_list的模型实现一些不错的交互界面,这些界面可以对我的mRails应用程序中的列表进行排序。我有一个排序函数,在每次拖放之后使用sortable_elementscript.aculo.us函数调用并设置每条记录的位置。这是在拖放完成后处理排序的Controller操作示例:defsortparams[:documents].each_with_indexdo|id,index|Document.update_all(['position=?',index+1],['id=?',id])endend现在我正在尝试对嵌套集模型(acts_as_nested

  3. 你真正了解什么是接口测试么?接口实战一“篇”入魂 - 2

    最近在工作中,看到一些新手测试同学,对接口测试存在很多疑问,甚至包括一些从事软件测试3,5年的同学,在聊到接口时,也是一知半解;今天借着这个机会,对接口测试做个实战教学,顺便总结一下经验,分享给大家。计划拆分成4个模块跟大家做一个分享,(接口测试、接口基础知识、接口自动化、接口进阶)感兴趣的小伙伴记得关注,希望对你的日常工作和求职面试,带来一些帮助。注:文章较长有5000多字,希望小伙伴们认真看完,当然有些内容对小白同学不是太友好,如果你需要详细了解其中的一些概念或者名词,请在文章之后留言,后续我将针对大家的疑问,整理输出一些大家感兴趣的文章。随着开发模式的迭代更新,前后端分离已不是新的概念,

  4. ruby-on-rails - 在 Ruby on Rails 中为由外部 API 支持的模型使用 ActiveRecord 接口(interface) - 2

    我正在尝试在我的Rails应用程序中使用模型来从外部API检索信息。我想做的是以类似于ActiveRecord模型提供的方式(特别是关联,以及相同风格的可链接查询方法)访问我的数据模型(可能包含来自多个API调用的信息)。我最初的直觉是重新创建我想要的ActiveRecord部分并合并此API。不想“重新发明轮子”并确切地看到添加更多功能需要多少工作让我退后一步并重新评估如何处理这个问题。我找到了在没有表的情况下使用ActiveRecord的方法(请参阅:Railscast#193TablelessModel和博客文章here)并研究了ActiveRecord。因为ActiveMode

  5. ruby - Interface Builder 看不到 MacRuby 的 socket - 2

    我正在尝试使用XCode和InterfaceBuilder构建一个基本的helloworld应用程序。但是,在InterfaceBuilder中,我看不到我的socket可以连接起来。我转到对象检查器Pane的连接选项卡,它显示“NewReferencingOutlet”。我想知道我的代码是否有误。在这里classHelloWorldControllerattr_accessor:hello_label,:hello_button,:hellodefawakeFromNib@hello=trueenddefchangeLabel(sender)if@hello@hello_label.

  6. [译]在C#中使用IComparable和IComparer接口 - 2

    原文:UsetheIComparableandIComparerinterfacesinVisualCSharp本文介绍了在VisualC#中如何使用IComparer和IComparable接口。概要本文同时讨论了IComparable和IComparer接口,原因有两点。这两个接口经常一起使用。虽然接口类似且名称相似,但它们却有不同的用途。如果你有一个支持IComparer的类型数组(例如字符串或整数),你可以对它进行排序而不需要提供任何对IComparer的显式引用(译注:意思是把一个IComparer的实现类作为参数传递给排序方法)。在这种情况下,数组元素会被转换为IComparer的

  7. API淘宝数据接口 - 2

    如果你想在自己的应用中使用淘宝的数据,那么对接淘宝数据接口是必不可少的一步。本文将介绍如何对接API淘宝数据接口,以便你能够顺利获取和使用淘宝的数据。步骤一:​​获取AppKey和AppSecret​​首先,在淘宝开放平台申请API接口之前,需要先注册为淘宝开发者并创建应用。创建应用后,你将得到一个AppKey和AppSecret,这两个参数需要在调用API接口时用于身份验证。步骤二:确定需要调用的API接口在淘宝开放平台的开发文档中,你将找到所有可用的API接口。你需要根据你的需求找到需要调用的API接口,例如查询商品、店铺等信息。在找到需要的API接口后,你需要了解该接口的请求参数和返回结

  8. ruby - 如何使用 Devise 来保护 delayed_job_web 接口(interface)? - 2

    我正在使用delayed_job_webgem来监控延迟的作业。https://github.com/ejschmitt/delayed_job_web可以使用我的routes.rb中的这一行访问它:match"/delayed_job"=>DelayedJobWeb,:anchor=>false我站点的每个其他区域都需要使用Devisegem登录。我如何使它也需要登录?在自述文件中,他们建议将以下内容添加到config.rb:ifRails.env.production?DelayedJobWeb.useRack::Auth::Basicdo|username,password|us

  9. ruby - 在 Ruby 中编写 C 接口(interface)比在 Perl 中更容易吗? - 2

    根据officialrubyAboutpage用C扩展Ruby比用Perl更容易。我不是(perl)XS专家,但我发现使用Inline::C快速简单地编写一些东西非常简单,那么为什么在Ruby中更容易呢?WritingCextensionsinRubyiseasierthaninPerlorPython,withaveryelegantAPIforcallingRubyfromC.ThisincludescallsforembeddingRubyinsoftware,foruseasascriptinglanguage.ASWIGinterfaceisalsoavailable.那些做

  10. ruby - 为什么 Ruby 人说他们不需要接口(interface)? - 2

    Ruby是否与其他OOP语言(例如:PHP)不同,使接口(interface)变得无用?它有某种替代品吗?编辑:一些说明:在其他语言中(例如:PHP),您并不“需要”接口(interface)(它们在代码级别不是强制性的)。你用它们来订立契约(Contract),改进软件的架构。因此,'在ruby​​中你不需要接口(interface)/在其他语言中你需要接口(interface)因为XXX'的断言是错误的。不,混合不是接口(interface),它们是完全不同的东西(PHP5.4实现了混合)。你用过接口(interface)吗?是的,PHP是OOP。语言不断发展,欢迎来到现在。

随机推荐