2021-09-10

JS学习笔记(运算符):

运算符也叫操作符

通过运算符可以对一个或多个值进行运算,并获取运算结果
比如:typeof就是运算符,可以获得一个值的类型,它会将该值返回一个字符串形式返回

学习内容:

算数运算符

	当对非Number类型的值进行运算时,会将这些值转换为Number然后再运算
	任何值和NaN做运算都得NaN

	+  
		+ 可以对两个值进行加法运算,并将结果返回
		如果对两个字符串进行加法运算,则会做拼串操作,就是将两个字符串拼接为一个字符串,并返回
		任何的值和字符串做加法运算,都会先转换为字符串,然后再和字符串做拼串的操作
			我们可以利用这一特点,来将一个任意的数据类型转换为String类型
			我们只要为任意数据类型 + 一个""(空串)即可将其转换为String类型,这是一种隐式类型转换,
		由浏览器自动完成,实际上它也是调用String()函数
	- 
		- 可以对两个值进行减法法运算,并将结果返回
	* 
		* 可以对两个值进行乘法法运算,并将结果返回
	/ 
		/ 可以对两个值进行除法法运算,并将结果返回
	%
		%可以对两个数进行取余运算,并将结果返回
	
	任何值做-  * /运算时都会自动转换为Number
		我们可以利用这一特点做隐式类型转换
			可以通过为一个值 -0, *1, /1来将其转化为Number
			原理和Number()函数一样,使用起了更加简单

一元运算符,只需要一个操作数

	+ 正号
			正号不会对数字产生任何影响
	- 负号
			负号可以对数字进行负号的取反

	对于非Number类型的值
		它会先将其转换为Number,然后在运算
		可以对一个其它的数据类型使用+,来将其转换为number
		它的原理和Number()函数一样

自增和自减:

	自增++
			通过自增可以使变量在自身的基础是增1
			对于一个变量自增以后,原变量的值会立即增1
			自增分为两种:前++(++a)和后++(a++)
					无论是++a还是a++,都会立即使原变量的值自增1
						不同的是,a++和++a的值不同
					a++的值等于原变量的值(自增前的值)
					++a的值等于原变量自增后的值(自增后的值)
			(注:a是变量,a++和++a是表达式,变量有变量的值,表达式有表达式的值)
	自减--
			通过自减可以使变量在自身的基础是减1
			自减分为两种:前--(--a)和后--(a--)
					无论是--a还是a--,都会立即使原变量的值自减1
						不同的是,a--和--a的值不同
					a--的值等于原变量的值(自减前的值)
					--a的值等于原变量自减后的值(自减后的值)

逻辑运算符:

&&(与)	||(或)	!(非)
	&&(与):
			&&(与)可以对符号两侧的值进行与运算并返回结果
			运算规则:
				两个值都为true时才会返回true
				两个值只要有一个为false就直接返回false
			JS中的“与”属于短路的与,
				如果第一个值为false,则不会检查第二个值,直接返回false
				如果第一个值为true,则会检查第二个值,且返回值与第二个值相同
	||(或):
			||(或)	可以对符号两侧的值进行运算并返回结果
			运算规则:
				两个值都为false时才会返回false
				两个值只要有一个为true就直接返回true
			JS中的“或”属于短路的或,
				如果第一个值为true,则不会检查第二个值,直接返回true
				如果第一个值为false,则会检查第二个值,且返回值与第二个值相同
	!(非):
			!(非)	可以用来对一个值进行非运算
			所谓非运算就是指对一个布尔值进行取反操作,
				true变false,false变成true
			如果对一个值进行两次取反,它不会变化
			如果对非布尔值进行运算,则会先将其转换为布尔值,然后再取反
				所以我们可以利用这一特点,来将一个其它数据类型转换为布尔值
				可以为一个任意数值的数据类型取两次反,来将其转换为布尔值,
			原理和Boolean()函数一样

非布尔值的与或运算:

&& 	||	非	布尔值的运算情况:
	对于非布尔值进行与运算时,
		会先将其转换为布尔值,然后再运算,并且返回原值
		如果两个值都为true,则返回后面的值;如果两个值都为false,则返回第一个值;如果一个为true,一个为false则返回false的值。
		(如果第一个为true,直接返回第二个值;如果第一个为false,则直接返回第一个值!)
	对于非布尔值进行或运算时,
		会先将其转换为布尔值,然后再运算,并且返回原值
		如果两个值都为true,则返回前面的值;如果两个值都为false,则返回第二个值;如果一个为true,一个为false则返回true·的值。
		(如果第一个为true,直接返回第一个值;如果第一个为false,则直接返回第二个值!)

赋值运算符:

=	可以将符号右侧的值赋值给符号左侧的变量
+=	:	a += 5	等价于	a  =  a + 5
-=	:	a -= 5	等价于	a  =  a - 5
*=	:	a *= 5	等价于	a  =  a * 5
/=	:	a /= 5	等价于	a  =  a / 5
%=	:	a %= 5	等价于	a  =  a % 5

关系运算符:

通过关系运算符可以比较两个值之间的大小关系,
	如果关系成立它会返回true,如果关系不成立它会返回false

>	大于号
	判断符号左侧的值是否大于右侧的
	如果关系成立,返回true,如果关系不成立则返回false
>=	大于或等于号
	判断符号左侧的值是否大于或等于右侧的
	如果关系成立,返回true,如果关系不成立则返回false
<	小于号
	判断符号左侧的值是否小于右侧的
	如果关系成立,返回true,如果关系不成立则返回false
<=	小于或等于号
	判断符号左侧的值是否小于或等于右侧的
	如果关系成立,返回true,如果关系不成立则返回false

非数值的关系运算:

非数值的情况下:
	对于非数值进行比较时,会将其转化为数字然后再比较
	如果两侧都是字符串时,不会将其转换为数字进行比较,而是分别比较字符串中字符的Unicode编码
	比较两个字符串时,比较的是字符串的字符编码
	比较字符编码时是一位一位进行比较的
	如果两位一样,则比较下一位,所以借用它来对英文进行排序
	比较中文时没有意义
	如果比较两个字符串类型的数字,可能会得到不可预期的结果
	注:在比较两个字符串数字时,一定要转型

相等运算符:

想等运算符用来比较两个值是否相等,
	如果相等返回true,否则返回false
使用==来做相等运算
	当使用==来比较两个值时,如果值的类型不同
	则会自动进行类型转换,将其转换为相同类型,然后再比较
undefined衍生自null
	所以这两个值做相等判断时,会返回true
NaN不和任何值相等,包括它本身
	可以通过isNaN()函数来判断一个值是否是NaN

不相等:
	不相等用来判断两个值是否不相等,如果不相等返回true,否则返回false
	使用 != 来做不相等判断
	不相等它会对变量进行自动的类型转换,如果转换后相等它也会返回false,否则返回true

全等 ===
	用来判断两个值是否全等,它和==类似,不同的是它不会做自动类型转换
	如果两个值的类型不同,直接返回false
不全等 !==
	用来判断两个值是否不全等,它和!=类似,不同的是它不会做自动类型转换
	如果两个值的类型不同,直接返回true

条件运算符:

条件运算符也叫三元运算符:
	语法:
			条件表达式?语句1:语句2;
		执行流程:
			条件运算符在执行时,首先条件表达式进行求值,
				如果该值为true,则执行语句1,并且返回执行结果
				如果该值为false,则执行语句2,并且返回执行结果
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用python中的pymsql完成如下:表结构与数据创建 1. 建立 `users` 表和 `orders` 表。 `users` 表有用户ID、用户名、年龄字段,(id,name,age) `orders` 表有订单ID、订单日期、订单金额,用户id字段。(id,order_date,amount,user_id) 2 两表的id作为主键,`orders` 表用户id为users的外键 3 插入数据 `users` (1, '张三', 18), (2, '李四', 20), (3, '王五', 22), (4, '赵六', 25), (5, '钱七', 28); `orders` (1, '2021-09-01', 500, 1), (2, '2021-09-02', 1000, 2), (3, '2021-09-03', 600, 3), (4, '2021-09-04', 800, 4), (5, '2021-09-05', 1500, 5), (6, '2021-09-06', 1200, 3), (7, '2021-09-07', 2000, 1), (8, '2021-09-08', 300, 2), (9, '2021-09-09', 700, 5), (10, '2021-09-10', 900, 4); 查询语句 1. 查询订单总金额 2. 查询所有用户的平均年龄,并将结果四舍五入保留两位小数。 3. 查询订单总数最多的用户的姓名和订单总数。 4. 查询所有不重复的年龄。 5. 查询订单日期在2021年9月1日至9月4日之间的订单总金额。 6. 查询年龄不大于25岁的用户的订单数量,并按照降序排序。 7. 查询订单总金额排名前3的用户的姓名和订单总金额。 8. 查询订单总金额最大的用户的姓名和订单总金额。 9. 查询订单总金额最小的用户的姓名和订单总金额。 10. 查询所有名字中含有“李”的用户,按照名字升序排序。 11. 查询所有年龄大于20岁的用户,按照年龄降序排序,并只显示前5条记录。 12. 查询每个用户的订单数量和订单总金额,并按照总金额降序排序。
06-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值