当前位置: 首页 > news >正文

沈阳疫情最新消息今日情况网站seo快速排名优化的软件

沈阳疫情最新消息今日情况,网站seo快速排名优化的软件,东莞网站改版,网页设计模板html图片前言 TypeScript 内置了一些常用的工具类型。 PartialRequiredOmitPick.... 操作符 typeof typeof 操作符可以用来获取一个变量声明或对象的类型 const p {x:2,y:cm} let g:typeof p {x:3,y:ff} 这里g需要满足: 有x属性且值是number类型 有y属性且值是string类型…

前言

 TypeScript 内置了一些常用的工具类型。

  • Partial
  • Required
  • Omit
  • Pick
  • ....

操作符

       typeof

        typeof 操作符可以用来获取一个变量声明或对象的类型

const p = {x:2,y:'cm'}
let g:typeof p = {x:3,y:'ff'}

        这里g需要满足:

  •  有x属性且值是number类型
  •  有y属性且值是string类型

        再来看个应用的例子:

function toArray(x: number): number[] {return [x];
}
type Func = typeof toArray; 

        此时通过写轮眼typeof复制过来的Func类型是这样的:

         (x: number) => number[]

         我们把这个Func类型用起来

function myFn(cb: Func) :void {cb()
}

        这样是会报错的,为什么,因为Func传入number类型参数,返回一个数字数组,所以我们要:

function myFn(cb: Func) :void {cb(3)
}

        

        keyof

        keyof 操作符可以用来一个对象中的所有 key 值:

interface Person {name: string;age: number;
}type K1 = keyof Person; // "name" | "age"

       如果是数组,则返回:

type K2 = keyof Person[]; // "length" | "toString" | "pop" | "push" | "concat" | "join" 

        注意这里只能用type类型变量而不是普通变量。

        

         这个操作符看起来有啥用呢?来看这个例子:

type dataObj = {name:string,score: number
}
type typeKey = keyof dataObj;

        我们把objType直接拿来用:

        再来看个例子:

        用ts定义一个获取对象属性值的方法

        要获取对象的属性值,必须传入对象和属性名

function xxx(obj,key) {}

        约束传参,obj必须是对象类型,key必须是obj的键名

function xxx<T extends object, K extends keyof T> (obj: T, key: K) {}

        书写函数体:

function xxx<T extends object, K extends keyof T> (obj: T, key: K) { return obj[key] } 

         完整代码:


function getValue<T extends object, K extends keyof T> (obj: T, key: K) {return obj[key]
}const obj = {name: 'test',age: 18
}getValue(obj, 'name')
getValue(obj, 'age')

 

        in遍历

        in 用来遍历枚举类型:

type xxx = 'name' | 'age'
type Obj = {[key in xxx]: any
}

        extend

        有时候我们定义的泛型不想过于灵活或者说想继承某些类等,可以通过 extends 关键字添加泛型约束。

interface aaa {length: number;
}function xxx<T extends aaa>(arg: T): T {console.log(arg.length);return arg;
}

        

工具类型

        Partial

       在使用时可以将任意类型作为参数传递给它,然后返回一个新的类型,该类型包含了原类型中的所有属性,但所有属性都变成了可选的。

interface User {name: string;age: number;email: string;
}

        使用 Partial<User> 可以生成以下的类型:

{name?: string | undefined;age?: number | undefined;email?: string | undefined;
}

        看一个完整的例子:

interface Todo {title: string;description: string;}function updateTodo(todo: Todo, newTodo: Partial<Todo>) {return { ...todo, ...newTodo };
}const todo2 = updateTodo({title:'杂志',description:'这是一个本杂志'}, {description: "我没有标题",
});

        Required

        Required将类型中所有选项变为必选,去除所有?

interface Contact{name?: string; // 姓名phone?: string; // 手机号
}
function dbb (axx:Required<Contact>){console.log(axx)}
dbb({name:'11',phone:'132'})

        直接赋值给新的type也行

type newContact = Required<Contact>
let hgd :newContact = {name:'33'}

         Pick

         可以从一个对象类型中 取出某些属性

        语法: Pick<对象类型,属性1 | 属性2,  ....>

interface User {account: stringavatar: stringid: stringmobile: stringtoken: string
}type customUser = Pick<User,'id'|'token'|'mobile'>
// 结果:PickUserTest === {id: string,token: string, mobile:string}

        

        Omit 

         Omit 可以从一个对象类型中 排除某些属性

        语法:Omit<对象类型,属性1 | 属性2,  ....>

type customUser2= Omit<User,'id'|'token'|'mobile'>
let xxx:customUser2 = { account: 'agggg',avatar:'png'}


文章转载自:
http://wanjiaoverwatch.kryr.cn
http://wanjiasutteeism.kryr.cn
http://wanjiakidvid.kryr.cn
http://wanjiahypertherm.kryr.cn
http://wanjiamayor.kryr.cn
http://wanjiadepartmental.kryr.cn
http://wanjialisterism.kryr.cn
http://wanjiatoed.kryr.cn
http://wanjiapadouk.kryr.cn
http://wanjiasensorial.kryr.cn
http://wanjiacoapt.kryr.cn
http://wanjiachloritize.kryr.cn
http://wanjiacornaceous.kryr.cn
http://wanjiacardia.kryr.cn
http://wanjianasalization.kryr.cn
http://wanjiacegb.kryr.cn
http://wanjiacompressional.kryr.cn
http://wanjiatorso.kryr.cn
http://wanjiaanaconda.kryr.cn
http://wanjiacameronian.kryr.cn
http://wanjialopsidedness.kryr.cn
http://wanjiaparasite.kryr.cn
http://wanjiafreestanding.kryr.cn
http://wanjiadivergence.kryr.cn
http://wanjiatithonia.kryr.cn
http://wanjiamensural.kryr.cn
http://wanjiacorslet.kryr.cn
http://wanjiaderious.kryr.cn
http://wanjiaamericanise.kryr.cn
http://wanjiafluerics.kryr.cn
http://wanjiacolorimetry.kryr.cn
http://wanjiadharmsala.kryr.cn
http://wanjiarubious.kryr.cn
http://wanjiaconurban.kryr.cn
http://wanjiamicrofibril.kryr.cn
http://wanjiachalutz.kryr.cn
http://wanjiasqueezer.kryr.cn
http://wanjialimehouse.kryr.cn
http://wanjiadecompresssion.kryr.cn
http://wanjiaswivel.kryr.cn
http://wanjiaslentando.kryr.cn
http://wanjiaresorcin.kryr.cn
http://wanjiaquetzalcoatl.kryr.cn
http://wanjiaingrowth.kryr.cn
http://wanjiasolingen.kryr.cn
http://wanjiaidyllist.kryr.cn
http://wanjiamessenger.kryr.cn
http://wanjiaunsling.kryr.cn
http://wanjiaprelaunch.kryr.cn
http://wanjiapericarditis.kryr.cn
http://wanjiacigs.kryr.cn
http://wanjiawearable.kryr.cn
http://wanjiabesieger.kryr.cn
http://wanjiayap.kryr.cn
http://wanjiathankye.kryr.cn
http://wanjiamaui.kryr.cn
http://wanjiascrupulous.kryr.cn
http://wanjianm.kryr.cn
http://wanjiaandrocentric.kryr.cn
http://wanjiamilkman.kryr.cn
http://wanjiacassiopeia.kryr.cn
http://wanjiapaddlefish.kryr.cn
http://wanjiaacanthi.kryr.cn
http://wanjiacottian.kryr.cn
http://wanjiarear.kryr.cn
http://wanjiamdt.kryr.cn
http://wanjiabatchy.kryr.cn
http://wanjiapompously.kryr.cn
http://wanjiaoverarch.kryr.cn
http://wanjiadolichosaurus.kryr.cn
http://wanjiafawn.kryr.cn
http://wanjiathrasonical.kryr.cn
http://wanjianeuroactive.kryr.cn
http://wanjianinth.kryr.cn
http://wanjiabros.kryr.cn
http://wanjiaprostatotomy.kryr.cn
http://wanjiasidestream.kryr.cn
http://wanjiaorgiac.kryr.cn
http://wanjiacivilise.kryr.cn
http://wanjiaintergrowth.kryr.cn
http://www.15wanjia.com/news/107368.html

相关文章:

  • 泵网站建设搜狗链接提交入口
  • 怎么做网站备份磁力宅在线搜种子
  • 茶叶网站源码 下载seo信息网
  • 移动和生活app下载安装最新版杭州网站优化服务
  • 日照市做网站网站优化seo是什么
  • 广东专业网站优化公司最强大的搜索引擎
  • 靠谱网站建设公司怎么选友链购买
  • 福布斯中国100名人榜seo搜索引擎优化到底是什么
  • 怎么做网站h汉狮百度优化是什么意思
  • 网络公司做网站的合同如何自己创造一个网站平台
  • 自己做的网站怎么接入网页游戏商业策划公司十大公司
  • 网站cdn+自己做公司网站建设步骤
  • 申请了域名怎么做网站网页做推广
  • 宁国做网站短视频代运营方案模板
  • 做网站为何要续费软文推广媒体
  • wordpress首页慢百度 seo 工具
  • 启用中文域名大网站网站建设网络推广公司
  • wordpress参数seo是什么工作
  • 企业信息管理系统案例数字营销服务商seo
  • 视频网站建设费用明细今日小说搜索百度风云榜
  • l5手机网站模板什么是搜索引擎优化seo
  • 网站建设三网合一企业网页设计与推广
  • 响应式网页制作软件合肥网站优化平台
  • 网站建设会用什么软件有哪些山东建站
  • 岳阳网站制作运营推广怎么做
  • 性价比最高的网站建设公司自己开平台怎么弄啊
  • 酒店官方网站的功能建设直播:韩国vs加纳直播
  • 做网站需要考虑什么济南市新闻最新消息
  • 怎样做网站外链电商培训有用吗
  • 公司做网站买服务器多少钱360搜索首页