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基础入门篇(七)—运算符的更多相关文章

  1. JS基础入门篇(三十五)—面向对象(二)

    如果没有面向对象这种抽象概念的小伙伴,建议先看一下我写的JS基础入门篇(三十四)-面向对象(一)

  2. JS基础入门篇(二十七)—BOM

    虽然上次写到js基础篇(二十四),这次直接写到(二十七).是为了提醒自己中间有几篇没写.特此说明一下啊. 1.window.open() 使用a标签呢,点击一下a标签页面才会跳转,有时候我们需要做的操 ...

  3. JS基础入门篇(六)— 数据类型

    1.数据类型 数据类型:我感觉就是对数据的种类进行分类.就好比把人分为儿童,青少年,中年,老年一样. 基础数据类型: Number(数字),String(字符串),Null(空),Undefined( ...

  4. JS基础入门篇( 三 )—使用JS获取页面中某个元素的4种方法以及之间的差别( 一 )

    1.使用JS获取页面中某个元素的4种方法 1.通过id名获取元素 document.getElementById("id名"); 2.通过class名获取元素 document.g ...

  5. JS基础入门篇(三)— for循环,取余,取整。

    1.for循环 1.for的基本简介 作用: 根据一定的条件,重复地执行一行或多行代码 语法: for( 初始化 ; 判断条件 ; 条件改变 ){ 代码块 } 2.for循环的执行顺序 <bod ...

  6. JS基础入门篇(四)—this的使用,模拟单选框,选项卡和复选框

    1.this的使用 this js中的关键字 js内部已经定义好了,可以不声明 直接使用 this的指向问题 1. 在函数外部使用 this指向的是window 2. 在函数内部使用 有名函数 直接调 ...

  7. JS基础入门篇(二十四)—DOM(下)

    1.offsetLeft/offsetTop offsetLeft/offsetTop : 到定位父级节点的距离. <!DOCTYPE html> <html lang=" ...

  8. JS基础入门篇(三十四)— 面向对象(一)

    1.对象 对象的定义 : 对象 是 由 键值对 组成的无序集合. 创建对象两种方法 : 方法一 : 字面量方法 var obj = {name: "k"}; 方法二 : new O ...

  9. JS基础入门篇(四十三)—ES6(二)

    1.对象简洁表示法 原来写法 var name = "lzf"; var gender = "male"; var fn = function(){consol ...

随机推荐

  1. package.json保存

    # 确保已经进入项目目录 # 确定已经有 package.json,没有就通过 npm init # 创建,直接一路回车就好,后面再来详细说里面的内容. # 安装 webpack 依赖 npm ins ...

  2. 最简单的flask项目详解

    # 第一部分,初始化:所有的Flask都必须创建程序实例, # web服务器使用wsgi协议,把客户端所有的请求都转发给这个程序实例 # 程序实例是Flask的对象,一般情况下用如下方法实例化 # F ...

  3. Linux驱动开发4——并发和竞态

    Linux系统处于一个高并发的运行环境,不管是系统调用还是中断都要求可重入,但是有一些系统资源处于临界区,因此,必须保证临界区资源访问的原子性. 对于临界区资源被占用时,发起访问的进程,有三种处理方法 ...

  4. zabbix自定义模板监控oracle

    zabbix服务器端安装:zabbix-3.2.6.tar.gzzabbix client端安装:zabbix-agent-3.2.6-1.x86_64.rpm 1.首先必须在目标机器安装zabbix ...

  5. 网络流小记(EK&dinic&当前弧优化&费用流)

    欢 迎 来 到 网 络 瘤 的 世 界 什么是网络流? 现在我们有一座水库,周围有n个村庄,每个村庄都需要水,所以会修水管(每个水管都有一定的容量,流过的水量不能超过容量).最终水一定会流向唯一一个废 ...

  6. 【C++】fill函数,fill与memset函数的区别

    转载自:https://blog.csdn.net/liuchuo/article/details/52296646 memset函数 按照字节填充某字符在头文件<cstring>里面fi ...

  7. pyspark 学习笔记

    from pyspark.sql import SparkSession spark = SparkSession \ .builder \ .appName("Python Spark S ...

  8. Delphi XE2 之 FireMonkey 入门(5) - TAlphaColor

    不是 TColor, 是 TAlphaColor 了. TAlphaColor = type Cardinal; 还是一个整数. 四个字节分别是: AA RR GG BB(透明度.红.绿.蓝); 这和 ...

  9. day16模块,导入模板完成的三件事,起别名,模块的分类,模块的加载顺序,环境变量,from...import语法导入,from...import *,链式导入,循环导入

    复习 ''' 1.生成器中的send方法 -- 给当前停止的yield发生信息 -- 内部调用__next__()取到下一个yield的返回值 2.递归:函数的(直接,间接)自调用 -- 回溯 与 递 ...

  10. STL关联式容器之set\map ----以STL源码为例

    关联式容器的特征:所用元素都会根据元素的键值自动被排序. set STL 中的关联式容器低层数据结构为红黑树,其功能都是调用低层数据结构中提供的相应接口. set元的元素不会像map那样同时拥有键(k ...