二、基本语法

一、变量声明

1、语法

<变量名称>: <变量类型> = <变量值>

2、变量类型

字符串:string

数值,整数、浮点数都可以:number

布尔:boolean

任意类型:any

联合类型,指定的多个类型中的一种:string|number|boolean

对象:类似json格式

数组:元素可以是任意其他类型

3、例子

variable1: string = "hello world"
variable2: number = 1
variable3: boolean = true
variable4: any = 'hello'
variable4 = 1
variable4 = true
variable5: string|number = 'world'
variable5 = 2
variable6 = {name: 'YAYA', age: 18}
console.log(variable6.name)
console.log(variable6['name'])
variable7: Array<string> = ['aaa', 'bbb']
variable8: number[] = [18,19]
console.log(variable7[0])
console.log(variable8[0])

4、实际运行效果

二、条件控制

1、if语法

空字符串、数字0、null、undefined

if(<条件>){
    <满足条件时执行的内容>        
}

if(<条件>){
    <满足条件时执行的内容>        
}else{
    <不满足条件时执行的内容>
}

if(<条件1>){
    <满足条件1时执行的内容>
}else if(<条件2>){
    <满足条件2时执行的内容>
}else{
    <不满足条件时执行的内容>
}

2、if语法执行结果

3、switch语法

switch (this.num){
    case 3: {
        this.msga = '合格';
        break;
    }
    case 6: {
        this.msga = '优秀';
        break;
    }
    default: {
        this.msga = '非法输入';
        break;
    }
}

4、switct语法执行结果

三、循环迭代

1、普通for 和 while 语法

// 普通for
for(let i = 0; i < 10; i++){
    //循环内容
}

// while
let i = 0;
while(i < 0){
    //循环内容
}

2、普通for 和 while 执行结果

3、迭代器

(1)、for in

遍历得到数组角标

let nums : string[] = ['10', '11']

for (const i in nums){
    console.log('for in :' + nums[i]);
}

(2)、for of

遍历直接得到元素

let nums : string[] = ['10', '11']

for (const num of nums){
    console.log('for of :' + num);
}

4、迭代器执行结果

四、函数

1、语法

function aa(){
  console.log('调用aa');
}
let bb = () => {
  console.log('调用bb');
}
function showLog(log: string){
  console.log(`显示Log:${log}`);
}
function sum(a: number, b: number): number{
  return a + b;
}
let cc = (a: number, b: number): number => {
  return a + b;
}
function showA(a?: string){
  console.log(`调用showA:${a ? a : '空'}。`)
}
function showB(a: string = "空"){
  console.log(`showB:${a}。`)
}

2、执行结果

五、类、接口、枚举

1、语法

//多态
//调用方式
let a: IA = new ClassA();
a.showLog(Code.Ok);


//声明方式
//定义枚举
enum Code{
  Ok = "200",
  NotOk = "400"
}
//定义接口
interface IA{
  showLog(log: Code): void
}
//实现接口
class ClassA implements IA{
  //构造函数
  constructor(msg: string) {
    console.log(`ClassA被构造了:${msg}`);
  }
  showLog(log: Code): void {
    console.log(`显示Log:${log}`);
  }
}

//继承
//调用方式
let b = new ClassC();
b.showMsg();

//声明方式
class ClassB{
  private msg: string
  constructor(msg: string) {
    this.msg = msg;
  }
  public showMsg(){
    console.log(this.msg);
  }
}
class ClassC extends ClassB{
  constructor() {
    super("这里是ClassC");
  }
}

2、执行结果

六、封装

1、语法

注意使用export导出方法,使用import导入方法

//ts文件 Demo1.ts
export enum Code{
  Ok = "200",
  NotOk = "400"
}
export interface IA{
  showLog(log: Code): void
}
export class ClassA implements IA{
  constructor(msg: string) {
    console.log(`ClassA被构造了:${msg}`);
  }
  showLog(log: Code): void {
    console.log(`显示Log:${log}`);
  }
}
export class ClassB{
  private msg: string
  constructor(msg: string) {
    this.msg = msg;
  }
  public showMsg(){
    console.log(this.msg);
  }
}
export class ClassC extends ClassB{
  constructor() {
    super("这里是ClassC");
  }
}

//方法调用文件
import {Code,IA,ClassA,ClassC} from '../entryability/Demo1'

let a: IA = new ClassA('ClassA');
a.showLog(Code.Ok);

let b = new ClassC();
b.showMsg();

2、执行结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/405246.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

springmvc+mybatis+springboot航空飞机订票售票系统_f48cp

互联网发展的越来越快了&#xff0c;在当下社会节点&#xff0c;人们也开始越来越依赖互联网。通过互联网信息和数据&#xff0c;极大地满足用户要求[5]。飞机订票系统使用了B/S模式&#xff0c;并且不需要安装第三方插件&#xff0c;他们甚至能直接在电脑上随机随地实现飞机订…

JavaScript运算符

文章目录 运算符介绍算术运算符递增和递减运算符比较运算符逻辑运算符短路运算逻辑与 逻辑或 赋值运算符运算符优先级 运算符介绍 算术运算符 %取余运算符的主要用途&#xff1a; 判断某个数是否能被某个数整除。 浮点数的精度问题&#xff1a; 所以&#xff1a;不要直接判断…

《一本书讲透 Elasticsearch》荣登当当人工智能新书榜

年前&#xff0c;《一本书讲透 Elasticsearch》荣登京东编程语言与程序设计榜前5名&#xff0c;今天又上榜当当人工智能新书榜第7名。 先看评价&#xff0c;看看大家阅后反馈 来自百度公司员工评价 来自Elastic原厂资深架构师评价 来自IBM资深架构师周钰老师的评价 来自2位阿里…

【Java程序员面试专栏 数据结构】一 高频面试算法题:数组

一轮的算法训练完成后,对相关的题目有了一个初步理解了,接下来进行专题训练,以下这些题目就是汇总的高频题目,本篇主要聊聊数组,包括数组合并,滑动窗口解决最长无重复子数组问题,图形法解下一个排列问题,以及一些常见的二维矩阵问题,所以放到一篇Blog中集中练习 题目…

鸿蒙开发市场憧憬如何?是否值得一冲~

自从华为放话&#xff1a;鸿蒙NEXT 不再支持安卓操作系统。换句话说&#xff0c;华为就是在向全世界宣布&#xff0c;华为官宣于2024年&#xff0c;不再支持安卓的AOSP。 大家也应该知道&#xff0c;谷歌暂停与华为的合作。为了生存&#xff0c;华为被迫突出了自研的鸿蒙操作系…

物麒平台自定义事件代码修改流程

是否需要申请加入数字音频系统研究开发交流答疑群(课题组)&#xff1f;可加我微信hezkz17, 本群提供音频技术答疑服务&#xff0c;群赠送蓝牙音频&#xff0c;DSP音频项目核心开发资料, 1 配置工具对应关系 2 事件处理 3 事件定义 4

滚雪球学Java(69):深入浅出Java中高效的ConcurrentLinkedQueue队列底层实现与源码分析

咦咦咦&#xff0c;各位小可爱&#xff0c;我是你们的好伙伴——bug菌&#xff0c;今天又来给大家普及Java SE相关知识点了&#xff0c;别躲起来啊&#xff0c;听我讲干货还不快点赞&#xff0c;赞多了我就有动力讲得更嗨啦&#xff01;所以呀&#xff0c;养成先点赞后阅读的好…

数据库面试题汇总,助你轻松应对面试!

考虑到最近有些小伙伴准备跳槽&#xff0c;所以更新一些数据库相关的面试题&#xff0c;希望能帮到大家&#xff01; 一 请写出创建表的基本语法结构&#xff1f; 创建表的基本语法结构如下&#xff1a; CREATE TABLE IF NOT EXISTS 表名(字段名1 字段类型,字段名2 字段类型 …

day08_面向对象-继承-课后练习 - 参考答案

文章目录 day08_课后练习代码阅读分析题第1题第2题第3题第4题第05题 代码编程题## 第1题第2题第3题第4题 day08_课后练习 代码阅读分析题 第1题 考核知识点&#xff1a;权限修饰符 如下代码是否可以编译通过&#xff0c;如果能&#xff0c;结果是什么&#xff0c;如果不能&…

计算机网络-网络互联与互联网(一)

1.常用网络互联设备&#xff1a; 1层物理层&#xff1a;中继器、集线器2层链路层&#xff1a;网桥、交换机3层网络层&#xff1a;路由器、三层交换机4层以上高层&#xff1a;网关 2.网络互联设备&#xff1a; 中继器Repeater、集线器Hub&#xff08;又叫多端口中继器&#xf…

基于PID控制器的直流电机位置控制系统simulink建模与仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 1. PID控制器原理 2. 位置控制环 5.完整工程文件 1.课题概述 基于PID控制器的直流电机位置控制系统。直流电机位置控制系统是工业自动化领域中的一个重要应用。为了实现精确的位置控制&#xff0c;常采…

2024 GMS(昆明)跨境电商交易博览会

2024 GMS&#xff08;昆明&#xff09;跨境电商交易博览会 招 展 手 册 立足大湄公河次区域&#xff0c;以云南为中心&#xff0c; 辐射南亚、东南亚的区域性国际跨境电商展会 展会背景&#xff1a; “十三五”以来&#xff0c;我国跨境电商行业在政策的推动下迎来了前所未…

通过platform总线驱动框架编写LED灯的驱动

通过platform总线驱动框架编写LED灯的驱动&#xff0c;编写应用程序测试 pdrv.c #include <linux/init.h> #include <linux/module.h> #include <linux/of_gpio.h> #include <linux/gpio.h> #include <linux/platform_device.h> #include <l…

【MATLAB源码-第143期】基于matlab的蝴蝶优化算法(BOA)机器人栅格路径规划,输出做短路径图和适应度曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 蝴蝶优化算法&#xff08;Butterfly Optimization Algorithm, BOA&#xff09;是基于蝴蝶觅食行为的一种新颖的群体智能算法。它通过模拟蝴蝶个体在寻找食物过程中的嗅觉导向行为以及随机飞行行为&#xff0c;来探索解空间&a…

构建生物医学知识图谱from zero to hero (4):通过Neo4j构建知识图谱

图数据库是一种专门用于存储图形数据的 NoSQL 数据库。与传统的关系型数据库和其他 NoSQL 数据库不同,图数据库利用图形数据模型来存储和管理数据。图形数据模型由节点和边组成,节点代表实体,边代表实体之间的关系。例如,在社交网络中,用户可以表示为节点,朋友关系可以表…

【SelectIO】bitslice原语学习记录

基本概念 在Ultrascale (plus)系列上的FPGA中&#xff0c;Xilinx引入了bitslice硬核&#xff0c;它取代了7系列上的IDELAYCTRL/IODELAY/IOSERDES/IODDR系列硬核&#xff0c;用于为HP&#xff08;High Performance&#xff09;类型Bank上的IO接口提供串并转化、信号延时、三态控…

JavaScript从零写网站《一瞬》开发日志20240223

产品介绍 一个无需注册能随时发布图片并配一段文字介绍的app&#xff0c;有时间线&#xff0c;用户在主页面向下滑动&#xff0c;可以看到被发布的若干图片&#xff0c;并且能够在每一个发布处做基本互动——评论&#xff0c;点赞 编程语言 本产品使用htmlcssJavaScript开发…

三种标注格式VOC、COCO、YOLO及其转换

最近在做基于深度学习的目标检测&#xff0c;数据标注软件选择的LabelImg。 常用的几种标注格式及目录安排 一、VOC(标注文件xml结尾) 首先看一下VOC格式的分布&#xff1a; 在VOC这些文件夹中&#xff0c;我们主要用到&#xff1a; ① JPEGImages文件夹&#xff1a;图片 ②…

Spring 手动实现Spring底层机制

目录 一、前言 二、Spring底层整体架构 1.准备工作 : 2.架构分析 : &#xff08;重要&#xff09; 3.环境搭建 &#xff1a; 三、手动实现Spring容器结构 1.自定义注解 : 1.1 Component注解 1.2 Scope注解 2.自定义组件 : 3.自定义用于封装Bean信息的BeanDefinition类&a…

第九节HarmonyOS 常用基础组件26-Radio

1、描述 单选框&#xff0c;提供相应的用户交互选择项。 2、接口 Radio(options:{value:string, group:string}) 3、参数 参数名 参数类型 必填 描述 value string 是 当前单选框的值。 group string 是 当前单选框的所属组名称&#xff0c;相同group的Radio只能…