JS基础入门篇(七)—运算符
1.算术运算符
1.算术运算符
- 算术运算符:+ ,— ,* ,/ ,%(取余) ,++ ,-- 。
- 重点:++和--前置和后置的区别。
1.1 前置 ++ 和 后置 ++
前置++:先自增值,再使用值。
后置++:先使用值,再自增值。
<script>
console.log("-------- 后置++ ----------");
var a=0;
console.log(a++);//0,后置是先用值,在自增值。
console.log(a);//1 自增后的值
console.log("-------- 前置++ ----------");
var b=2;
console.log(++b);//3 前置是先自增,后用值。
console.log(b);//3
console.log("-------- 后置++ ----------");
var d = 2;
var e = d++;// 后置是先用值,在自增值。
console.log( d,e );//3 2
console.log( "--------- 前置++ -------------" );
var f = 20;
var g = ++f;// 前置是先自增,后用值。
console.log( f,g );//21 21;
</script>
2.赋值运算符
2.赋值运算符
- 赋值运算符:+= ,—=*,= ,/= ,%= 。
- 计算完值后,并赋值给自己。
3.关系运算符
3.关系运算符
- <= , >= , == , != , === , !== 。
- 注意:返回的值都是布尔值。
3.1 == 和 === 的区别
- == 进行比较的时候,会比较 两者的内容,不进行数据类型的比较。
- === 不仅判断内容 ,还会判断 数据类型。
<script>
console.log(1=="1");//true 只比较内容,内容相等故为真。
console.log(1==="1");//false 不仅比较内容,还比较数据类型。数据类型不为真,故假。
console.log( 1 != "1" );//false
console.log( 1 !== "1" );//true
</script>
3.2需要记忆的内容
<script>
console.log( null == undefined );//true
console.log( null == 0 );//false
console.log( undefined == 0 );//false
</script>
4.逻辑运算符
- && (并且)
如果左边为真,返回右边的值。
如果左边为假,返回左边的值。 - || (或者)
如果左边为真,返回左边的值。
如果左边为假,返回右边的值 - ! (否)
把 !后面的数转成布尔值然后取反
<script>
console.log( 1 && 2 );//2
console.log( 0 && 2 );//0
console.log( 0 && "a" );//0
function fn(){
console.log("fn执行了");
}
false && fn();//不执行fn();
true && fn();//执行fn();
undefined && fn();//不执行fn();
console.log( 0 || 1 );//1
console.log( 2 || 1 );//2
var res = "a" || "b";
console.log( res );//"a"
console.log( !"false" );//"false"
</script>
5.三目运算符
三目运算符: 判断条件 ? 语句 1 : 语句 2
判断条件 成立 执行语句 1
不成立 执行语句 2
6.数组的存储
数组赋值的时候,传递的是数组的地址。
<script>
var a = 1;
var b = a; // 传值,把a的值给b
a = 2;
console.log( b );//得到的值是1.
//------------------------------------------
var arr = ["a","b"];
var res = arr; // 传址,赋址
arr[0] = 1;
console.log( arr );//根据地址找数组,得到的是["1","b"]
console.log( res );//根据地址找数组,得到的是["1","b"]
//------------------------------------------
var arr1 = ["a","b"];
var res1 = ["a","b"];
arr1[0] = 1;
//arr1数组的地址和res1数组的地址不相同,虽然内容相同。
console.log( arr1 );//根据地址找数组,得到的是["1","b"]
console.log( res1 );//根据地址找数组,得到的是[a","b"]
</script>
JS基础入门篇(七)—运算符的更多相关文章
- JS基础入门篇(三十五)—面向对象(二)
如果没有面向对象这种抽象概念的小伙伴,建议先看一下我写的JS基础入门篇(三十四)-面向对象(一)
- JS基础入门篇(二十七)—BOM
虽然上次写到js基础篇(二十四),这次直接写到(二十七).是为了提醒自己中间有几篇没写.特此说明一下啊. 1.window.open() 使用a标签呢,点击一下a标签页面才会跳转,有时候我们需要做的操 ...
- JS基础入门篇(六)— 数据类型
1.数据类型 数据类型:我感觉就是对数据的种类进行分类.就好比把人分为儿童,青少年,中年,老年一样. 基础数据类型: Number(数字),String(字符串),Null(空),Undefined( ...
- JS基础入门篇( 三 )—使用JS获取页面中某个元素的4种方法以及之间的差别( 一 )
1.使用JS获取页面中某个元素的4种方法 1.通过id名获取元素 document.getElementById("id名"); 2.通过class名获取元素 document.g ...
- JS基础入门篇(三)— for循环,取余,取整。
1.for循环 1.for的基本简介 作用: 根据一定的条件,重复地执行一行或多行代码 语法: for( 初始化 ; 判断条件 ; 条件改变 ){ 代码块 } 2.for循环的执行顺序 <bod ...
- JS基础入门篇(四)—this的使用,模拟单选框,选项卡和复选框
1.this的使用 this js中的关键字 js内部已经定义好了,可以不声明 直接使用 this的指向问题 1. 在函数外部使用 this指向的是window 2. 在函数内部使用 有名函数 直接调 ...
- JS基础入门篇(二十四)—DOM(下)
1.offsetLeft/offsetTop offsetLeft/offsetTop : 到定位父级节点的距离. <!DOCTYPE html> <html lang=" ...
- JS基础入门篇(三十四)— 面向对象(一)
1.对象 对象的定义 : 对象 是 由 键值对 组成的无序集合. 创建对象两种方法 : 方法一 : 字面量方法 var obj = {name: "k"}; 方法二 : new O ...
- JS基础入门篇(四十三)—ES6(二)
1.对象简洁表示法 原来写法 var name = "lzf"; var gender = "male"; var fn = function(){consol ...
随机推荐
- 关于跨域踩的坑,浏览器 status code为200,但实际上是跨域了
背景 后端使用Nginx并更改本地host文件,起本地服务.将aaa.bbbb.com代理至本地IP地址(10.26.36.156).使用$.ajax调用后端restful接口,要求content-t ...
- java设置RabbitMQ的消费处理出现:ConditionalRejectingErrorHandler : Execution of Rabbit message listener failed.
WARN 7868 --- [cTaskExecutor-1] s.a.r.l.ConditionalRejectingErrorHandler : Execution of Rabbit messa ...
- 阶段1 语言基础+高级_1-3-Java语言高级_06-File类与IO流_07 缓冲流_3_BufferedInputStream_字节缓冲
内容改成abc 来个数组缓冲
- Chromely
Chromely Chromely is a lightweight alternative to Electron.NET, Electron for .NET/.NET Core develope ...
- 使用fiddler,提示系统找不到相应的文件FSE2.exe文件
使用fiddler时候遇到了如下问题: Rules中customize rules 时,提示系统找不到相应的文件FSE2.exe文件. 这个文件的位置可以在Tools->opinions-> ...
- gdi+ 中发生一般性错误
1.检查文件夹权限 2.保存的文件已存在并因某种原因被锁定. 3.文件夹路径不存在
- docker--docker介绍
2 docker 介绍 2.1 容器技术 在计算机的世界中,容器拥有一段漫长且传奇的历史.容器与管理程序虚拟化 (hypervisor virtualization,HV)有所不同,管理程序虚拟化通过 ...
- repr_str方法
该方法可以改变字符串的显示格式 class School: def __init__(self,name,addr,type): self.name = name self.addr = addr s ...
- centos7下搭建Testlink环境详细过程
花了半天的时间终于搭建好了完整的Testlink环境,主要包括Mysql以及PHP的版本.未关闭防火墙.以及安装配置过程中遇到的一些问题.以下是详细的搭建过程. 一.工具准备 以下是我在搭建过程中用到 ...
- JDK 13 的 12 个新特性,真心涨姿势了
作者:木九天 my.oschina.net/mdxlcj/blog/3107021 1.switch优化更新 JDK11以及之前的版本: switch (day) { case MONDAY: cas ...