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

建设网站学什么条件wordpress设计网页游戏

建设网站学什么条件,wordpress设计网页游戏,海淀网站制作服务公司,做推广公司typescript是js的超集#xff0c;目前很多前端框架都开始使用它来作为项目的维护管理的工具#xff0c;还在不断地更新#xff0c;添加新功能中#xff0c;我们学习它#xff0c;才能更好的在的项目中运用它#xff0c;发挥它的最大功效 //readonly 只能修饰属性#x…typescript是js的超集目前很多前端框架都开始使用它来作为项目的维护管理的工具还在不断地更新添加新功能中我们学习它才能更好的在的项目中运用它发挥它的最大功效 //readonly 只能修饰属性不能修饰方法 //readonly修饰的属性必须手动添加明确的类型否则就是字面量类型 class Person {//只读属性readonly age:number 18constructor(age:number) {this.age age}//错误展示// readonly setAge() {// // this.age 20// } }//接口或者{}表示的对象类型,里面的属性也是可以用readonly来修饰的 interface IPerson{readonly name:string }let obj: IPerson {name:JACK }obj.name rose//类型兼容性 //分为结构化类型系统和标明类型系统 //TS采用的是结构化类型系统也叫duck typing(鸭子类型) //类型检查关注的是值所具有的形式 //也就是在结构类型系统中如果两个类型对象具有相同的形状则认为他们属于同一类型 class Point {x: numbery:number }class Point2D {x: numbery:number }const p: Point new Point2D()//如果在表明类型系统中c#,java则两个类型不是同的 class Point3D{x: numbery: numberz:number }const p1: Point new Point3D() const p2: Point new Point()//错误演示 const p3: Point3D new Point()//Point3D 至少与Point相同则Ponit兼容Point3D //所以成员多的Ponit3D可以赋值给成员少的Ponit //接口之间的兼容性类似于class //函数之间的兼容性比较复杂 //参数个数参数多的的兼容参数少的即参数少的可以赋值给参数多的 //参数类型,相同位置的参数类型要相同原始类型或兼容对象类型 //返回值类型 type F1 (a: number) void type F2 (a: number, b: number) voidlet f1: F1 let f2: F2 f1//错误演示,参数多的不能付给参数少的 let f3: F1 f2//参数多的兼容少的少的可以赋值给多的 const arr [1,2,3,4,5]const a1 arr.map((el) el)const a2 arr.map(() console.log(1111111))type F3 (a: number) string type F4 (a: number) stringlet f4: F3 let f5:F4 f4 f5 f5 f4//技巧:将对象拆开把每个属性看做一个个参数参数少的就可以赋值给参数多的 //返回值类型 //如果返回值类型是基本类型相同则互相兼容 type F8 () string type F9 () stringlet f8: F8 let f9: F9 f8 f8 f9//若果是对象类型则成员多的可以赋值给少的 type F10 () {name:string} type F11 () { name: string, age: number }let f10: F10 let f11: F11f10 f11 //错误演示 f11 f10//交叉类型 //类似于接口继承用于组合多个类型为一个类型常用语对象类型 //是新类型同时具备了多个类型的属性类型 interface Person {name:string }interface Age{age:number }type IPerson Person Agelet obj: IPerson {name: GAOFENG,age: 20, }type P {name:string} type A { age: number }type C P Alet obj2: C {name: gaogeng,age:30 }//交叉类型和接口继承的对比 //相同点:都可以实现对象类型的组合 //不同点实现继承时处理同名类型冲突的方式不一样 //接口继承会报错交叉类型没有错误 interface A1 {fn:(a:string) string } interface B1 extends A1 {fn:(a:number) string }interface C1 {fn:(a:number) string }type C4 A1 C1let c: C4 {fn(name:string|number) {// return name as stringreturn stringname} } c.fn(task...) c.fn(33333)
http://www.sadfv.cn/news/46432/

相关文章:

  • 做3d效果图的网站哪里网站备案
  • 做网站的品牌公司有哪些美食网站建设的功能
  • 网站开发 所有权成都前几年网站建设公司
  • 招标网站排行榜企业品牌战略
  • 临沂制作手机网站提供常州网站推广
  • 网站怎么下载视频茂名营销型网站制作公司
  • wordpress搭建cms网站大学网站建设的目标与思路
  • 触屏端网站开发微信公众号登录wordpress网站吗
  • 网站的ftp地址怎么查电商网站通用左侧弹出导航
  • 搜英文关键词网站域名解析平台网站建设
  • 中小型网站建设如何wordpress 图片管理插件
  • 铜陵保障性住房和城乡建设网站人工智能培训课程
  • 网站制作div区域是哪儿网站安全的必要性
  • 个体户做盈利网站网站设计案例欣赏
  • 宣传 网站建设方案模板外贸推广方式有哪些
  • 做百度网站每年的费用多少wordpress支持HTML么
  • 腾讯云怎么备案网站新人0元购物软件
  • 网站建设运营费用包括哪些广州最新新闻事件
  • asp汽车销售公司网站源码 4s店网站源码 汽车网站建设 完整无县电子政务办网站建设工作思路
  • 宁波网站优化如何网站建设有哪些模块
  • 公司网站二维码怎么做的网页设计公司概念
  • 网站制作五个界面公司合法网站域名怎么注册
  • pc端的网站设计方案网络营销方式多样
  • 网站建设开发报价义乌广告设计与制作
  • 泰安网站建设最好wordpress照片库
  • 搭建网站需要什么技能wordpress怎么添加栏目
  • 如何免费做网站赚钱淘宝上网站建设为啥这么便宜
  • 长岭建设局网站dede网站
  • 网站维护与排名WordPress主题niRvana
  • 手机网站推荐几个广西和城乡建设厅网站