TypeScript(四) 运算符

news2025/1/13 10:29:43

1. 运算符

1.1. 描述

   运算符用于执行程序代码运算。

1.2. 运算符主要包括:

(1)算术运算符
(2)逻辑运算符
(3)关系运算符
(4)按位运算符
(5)赋值运算符
(6)三元/条件运算符
(7)字符串运算符
(8)类型运算符

1.3. 算术运算符

   y=5,对下面算术运算符进行解释:
在这里插入图片描述
  实例:

/**
  * 算术运算
  */
  countData: function () {
    var num1:number = 10 
    var num2:number = 2
    var res:number = 0
    res = num1 + num2 
    console.log("加:        "+res); 
    res = num1 - num2; 
    console.log("减: "+res) 
    res = num1*num2 
    console.log("乘:    "+res) 
    res = num1/num2 
    console.log("除:   "+res)  
    res = num1%num2 
    console.log("余数:   "+res)  
    num1++ 
    console.log("num1 自增运算: "+num1) 
    num2-- 
    console.log("num2 自减运算: "+num2)
  },

在这里插入图片描述

1.4. 关系运算符

  关系运算符用于计算结果是否为true或者false。
  X=5,对下面关系运算符进行解释:
在这里插入图片描述

  /**
    * 关系运算
    */
  relationData: function () {
    var num1: number = 5;
    var num2: number = 9;
    console.log("num1 的值为: " + num1);
    console.log("num2 的值为:" + num2);
    var res: boolean = true
    res = num1 > num2;
    console.log("num1 大于n num2: " + res);
    res = num1 < num2;
    console.log("num1 小于 num2: " + res);
    res = num1 >= num2;
    console.log("num1 大于或等于  num2: " + res);
    res = num1 <= num2;
    console.log("num1 小于或等于 num2: " + res);
    res = num1 == num2;
    console.log("num1 等于 num2: " + res);
    res = num1 != num2;
    console.log("num1 不等于 num2: " + res);
  },

在这里插入图片描述

1.5. 逻辑运算符

  逻辑运算符用于测定变量或值之间的逻辑。
  给定x=6以及y=3,对一下逻辑运算符进行解释:
在这里插入图片描述

  /**
    * 逻辑运算
    */
   logicData: function () {
    var avg:Number = 20;
    var percentage:Number = 90;
    console.log("avg 值为: " + avg + " ,percentage 值为: " + percentage);
    var res:boolean = ((avg > 50) && (percentage > 80));
    console.log("(avg>50)&&(percentage>80): ", res);
    var res:boolean = ((avg > 50) || (percentage > 80));
    console.log("(avg>50)||(percentage>80): ", res);
    var res :boolean= !((avg > 50) && (percentage > 80));
    console.log("!((avg>50)&&(percentage>80)): ", res);
   },

在这里插入图片描述

1.6. 短路运算符(&&与||)

  && 与 || 运算符可用于组合表达式。 && 运算符只有在左右两个表达式都为 true 时才返回 true。
  实例1:

    var a: Number = 10
    var result: boolean = (a < 10 && a > 5)
    console.log("短路运算符(&&):" + result)

  以上实例中 a < 10 与 a > 5 是使用了 && 运算符的组合表达式,第一个表达式返回了 false,由于 && 运算需要两个表达式都为 true,所以如果第一个为 false,就不再执行后面的判断(a > 5 跳过计算),直接返回 false。
   || 运算符只要其中一个表达式为 true ,则该组合表达式就会返回 true。
  实例2:

    var a: Number = 10 
    var result: boolean = ( a>5 || a<10)
    console.log( result)

  实例中 a > 5 与 a < 10 是使用了 || 运算符的组合表达式,第一个表达式返回了 true,由于 || 组合运算只需要一个表达式为 true,所以如果第一个为 true,就不再执行后面的判断(a < 10 跳过计算),直接返回 true。

1.7. 位运算符

  位操作是程序设计中对位模式按位或二进制数的一元和二元操作
在这里插入图片描述
  实例

  /**
  * 位运算
  */
  bitData: function () {
    var a = 2; // 二进制 10 
    var b = 3; // 二进制 11
    var result;
    result = (a & b);
    console.log("(a & b) => ", result);
    result = (a | b);
    console.log("(a | b) => ", result);
    result = (a ^ b);
    console.log("(a ^ b) => ", result);
    result = (~b);
    console.log("(~b) => ", result);
    result = (a << b);
    console.log("(a << b) => ", result);
    result = (a >> b);
    console.log("(a >> b) => ", result);
    result = (a >>> 1);
    console.log("(a >>> 1) => ", result);
  },

在这里插入图片描述

1.8. 赋值运算符

  赋值运算符用于给变量赋值。
  x=10 和 y=5,下面的表格解释了赋值运算符:
在这里插入图片描述
  备注:类似的逻辑运算符也可以与赋值运算符联合使用:<<=, >>=, >>>=, &=, |= 与 ^=。
  实例:

  /**
 * 赋值运算
 */
  assignmentData: function () {
    var a = 12;
    var b = 10;
    a = b;
    console.log("a = b: " + a);
    a += b;
    console.log("a+=b: " + a);
    a -= b;
    console.log("a-=b: " + a);
    a *= b;
    console.log("a*=b: " + a);
    a /= b;
    console.log("a/=b: " + a);
    a %= b;
    console.log("a%=b: " + a);
  },

在这里插入图片描述

1.9. 三元运算符

  三元运算有 3 个操作数,并且需要判断布尔表达式的值。该运算符的主要是决定哪个值应该赋值给变量。
  Test ? expr1 : expr2
  Test − 指定的条件语句
  expr1 − 如果条件语句 Test 返回 true 则返回该值
  expr2 − 如果条件语句 Test 返回 false 则返回该值
实例:

  /**
 * 赋值运算
 */
  assignmentData: function () {
  /**
  * 三元运算符
  */
  threeData: function () {
    var num:Number = -2;
    var result:string = num > 0 ? "大于 0" : "小于 0,或等于 0";
    console.log(result);
  },

在这里插入图片描述

1.10. 三元运算符

  typeof 运算符
  typeof 是一元运算符,返回操作数的数据类型。
实例:

  /**
   * 类型运算符
   */
  classData: function () {
    var num = 12;
    console.log(typeof num); //输出结果: number
  },

在这里插入图片描述

1.11. 其它运算符

  负号运算符(-)
  实例:

  /**
   * 负号运算符(-)
   */
  negativeData: function () {
    var x = 6;
    var y = -x;
    console.log("x 值为: ", x); // 输出结果 6
    console.log("y 值为: ", y); // 输出结果 -6
  },

在这里插入图片描述
  字符串运算符: 连接运算符 (+)
  实例:

   /**
 * 字符串运算符: 连接运算符 (+)
 */
  positiveData: function () {
    var msg = "zhou" + "zhsh";
    console.log(msg);
  },

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C#算法(11)—求三个点构成圆的圆心坐标和半径

前言 我们在上位机开发领域也经常会碰到根据三个点求出圆的圆心、半径等信息的场景,本文就是详细的介绍如何根据三个点使用C#代码求出三点构成的圆的圆心坐标、圆半径、三点构成的圆弧的角度。 1、3点求圆分析 A、B、C三个点都是圆上的坐标点,过向量AB做中垂线,过向量AC做…

STP生成树协议实验

实验大纲 一、什么是生成树协议 二、生成树原理 1.STP工作原理 2.STP主要参数 3.STP根网桥 4.STP协议版本 三、实验 1.构建网络拓扑结构图 2.配置IP地址&#xff08;8台PC机&#xff09;&#xff1a;192.168.7.1~192.168.7.8 3.配置SW1 4.配置SW2 5.配置SW3 6.配置…

【英语趣味游戏】填字谜(Crossword)第1天

谜题出处 柯林斯字谜大全&#xff08;6&#xff09;&#xff0c;Collins——Big Book of Crosswords&#xff08;Book 6&#xff09; Puzzle Number: 114 本期单词 横向 1、Situation involving danger (4) 包含危险的情境&#xff0c;4个字母 答案&#xff1a;Risk&#xff…

第十一章 Linux实际操作——进程管理(重点)

第十一章 Linux实际操作——进程管理&#xff08;重点&#xff09; 11.1 基本介绍11.2 显示系统执行的进程11.2.1 基本介绍11.2.2 ps详解11.2.3 应用实例 11.3 终止进程kill和killall11.3.1 介绍11.3.2 基本语法11.3.3 常用选项11.3.4 最佳实践 11.4查看进程树pstree11.4.1 基本…

微服务-微服务Spring-cloud-open-feign

1. LoadBalancerRestTemplate的缺陷 LoadBalancerRestTemplate进行微服务调用 BeanLoadBalancedpublic RestTemplate restTemplate() {return new RestTemplate();}//调用方式String url "http://mall-order/order/findOrderByUserId/"id;R result restTemplate.…

路由进阶

文章目录 1.路由的封装抽离2.声明式导航 - 导航链接3.声明式导航-两个类名自定义匹配的类名 4.声明式导航 - 跳转传参查询参数传参动态路传参两种传参方式的区别动态路由参数可选符 5.Vue路由 - 重定向6.Vue路由 - 4047.Vue路由 - 模式设置8.编程式导航 - 两种路由跳转9.编程式…

Nginx负载均衡下的webshell连接

一、WebShell简介 “web”的含义是显然 需要服务器开放web服务&#xff0c;“shell”的含义是 取得对服务器某种程度上操作权限。 webshell&#xff0c;顾名思义&#xff1a;web指的是在web服务器上&#xff0c;而shell是用脚本语言编写的脚本程序&#xff0c;webshell就是就…

漏洞原理MySQL注入布尔盲注入

1 判断MySql注入点是否存在 利用盲注入的方式 http://127.0.0.1/news/show.php?id46 and 11 # 正常显示 http://127.0.0.1/news/show.php?id46 and 12 # 不显示 2 获取数据库的长度 http://127.0.0.1/news/show.php?id46 and length(database())n n的范围是从 1 开始 h…

Kotlin快速入门4

Kotlin的类与对象 类的定义 Kotlin使用关键字class来声明类。后面紧跟类名字&#xff1a; class LearnKotlin { //类名&#xff1a;LearnKotlin//... } Kotlin的类可以包含&#xff1a;构造函数和初始化代码块、函数、属性、内部类、对象声明。当然&#xff0c;也可以定义一…

BGP:05 BGP自动路由汇总

路由汇总&#xff0c;能有效地减少 BGP 路由器通告的路由条目数量&#xff0c;减小设备的路由表规模&#xff0c;并将拓扑变化产生的影响限制在一个相对更小的范围内。 自动路由聚合是在自然边界路由器上自动执行的&#xff0c;在默认情况下&#xff0c;BGP的自动路由聚合功能是…

go包与依赖管理

包&#xff08;package&#xff09; 包介绍 Go语言中支持模块化的开发理念&#xff0c;在Go语言中使用包&#xff08;package&#xff09;来支持代码模块化和代码复用。一个包是由一个或多个Go源码文件&#xff08;.go结尾的文件&#xff09;组成&#xff0c;是一种高级的代码…

springboot134英语知识应用网站的设计与实现

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…

深度强化学习(王树森)笔记07

深度强化学习&#xff08;DRL&#xff09; 本文是学习笔记&#xff0c;如有侵权&#xff0c;请联系删除。本文在ChatGPT辅助下完成。 参考链接 Deep Reinforcement Learning官方链接&#xff1a;https://github.com/wangshusen/DRL 源代码链接&#xff1a;https://github.c…

C++多线程2(复习向)

lock_guard lock_guard是C中提供的对互斥锁有关操作的高级接口&#xff0c;可对互斥锁进行自动上锁和解锁&#xff0c;多用于作为局部变量。&#xff08;在对象创建时&#xff0c;构造函数中自动为传入的互斥锁对象上锁&#xff0c;局部变量被系统回收时&#xff0c;其析构函数…

消失的数字(c语言多种解法)

题目 该题目取自力扣&#xff08;LeetCode&#xff09;面试题 17.04. 消失的数字 该题目主要考察时间复杂度的把握&#xff0c;题目如下&#xff1a; 数组nums包含从0到n的所有整数&#xff0c;但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(n)时间内完成吗&a…

幻兽帕鲁服务器出租,腾讯云PK阿里云怎么收费?

幻兽帕鲁服务器价格多少钱&#xff1f;4核16G服务器Palworld官方推荐配置&#xff0c;阿里云4核16G服务器32元1个月、96元3个月&#xff0c;腾讯云换手帕服务器服务器4核16G14M带宽66元一个月、277元3个月&#xff0c;8核32G22M配置115元1个月、345元3个月&#xff0c;16核64G3…

【MySQL】补充和navicat的一些简单使用

文章目录 前言在这里插入图片描述 事情起因因为这个articlecount的c是小写了&#xff0c;我想改成大写 一、修改二、navicat的使用步骤1.连接2.建库&#xff0c;建表 三.填写数据总结 前言 事情起因因为这个articlecount的c是小写了&#xff0c;我想改成大写 提示&#xff1a;…

[css] 让文字进行竖着 分散对齐

.demo2 {width: 60px;background-color: aqua;height: 200px;display: grid;place-items: center;}参考&#xff1a; css 让文字进行竖着书写&#xff0c; 附带个小知识&#xff0c;行内块元素添加文字之后底部对不齐的问题

系统架构15 - 软件工程(3)

软件过程模型 瀑布模型特点缺点 原型化模型特点两个阶段不同类型注意 螺旋模型V 模型特点 增量模型特点 喷泉模型基于构件的开发模型(CBSD)形式化方法模型敏捷模型特点“适应性” (adaptive) 而非“预设性” (predictive)“面向人的” (People-oriented) 而非“面向过程的” (P…

动态规划算法题刷题笔记

首先看动态规划的三要素&#xff1a;重叠子问题、最优子结构和状态转移方程。 重叠子问题&#xff1a;存在大量的重复计算 最优子结构&#xff1a; 状态转移方程&#xff1a;当前状态转移成以前的状态 动态规划的解题步骤主要有&#xff1a; 确定 dp 数组以及下标的含义状…