javascript中基本包装、算数运算符、递增递减运算符、赋值运算符、比较运算符、逻辑运算符、运算符优先级

基本包装类型:

指基本类型的数据变量通过调用属性或者方法包装成了复杂类型,这个变量也称为基本包装类型对象

	<script>var str = 'hello';str = str.replace('ll', 'ee');console.log(str); //heeeo//通过基本包装,无论Boolean对象中传入true还是false,在逻辑与中其结果都是&&后面的值:var flag = new Boolean(false)var result = flag && true;console.log(result); //truevar flag1 = new Boolean(true)var result1 = flag1 && true;console.log(result1); //truevar flag2 = new Boolean(true)var result2 = flag2 && false;console.log(result2); //false</script>

操作符

指一些符号,用来做运算的,具体如下:

算数运算符:

+、- 、 * 、/ 、%

	<script>//算数运算:console.log(111 + 222); //333console.log(111 - 222); //-111console.log(111 * 222); //24642console.log(111 / 222); //0.5console.log(5 % 3); //2var num = 10;var sum = (5 + num)*2;console.log(sum);//30</script>

递增递减运算符(一元运算符):

++ 、–(前置++(–)和后置++(–)的区别:前置++或–是先参与运算,之后在自身+1或-1;后置++或–是先自身+1或-1,之后在参与运算)、delete删除一个对象的属性或者一个数组中某一个键值、void 运算符(不常用)、in关系运算符(判断某个变量是否在某数据中)、

	<script>//也可以叫一元运算符:var num = 10;console.log(num++); //10console.log(num); //11console.log(++num); //12console.log(num); //12var num2 = 10;console.log(++num2); //11console.log(num2); //11console.log(num2++); //11console.log(num2); //12//后置++:先参与运算,运算完后自身在+1(后置--同理)//前置++:先自身+1,然后再参与运算(前置--同理)var num = 10;var sum = ++num + 10;console.log(sum); //21console.log(num); //11var num = 10;var sum = num++ + 10;console.log(sum); //20console.log(num); //11var num = 10;var sum = num++ + ++num; //特别注意,当num自己每运算一次,自己的值就会改变,因此:10 + 12 = 22console.log(sum); //22console.log(num); //12var num = 10;var sum = ++num + num++; //11 + 11 = 22console.log(sum); //22console.log(num); //12var num = 10;var sum = ++num + ++num; //11 + 12 = 23console.log(sum); //23console.log(num); //12var num = 10;var sum = num++ + num++; //10 + 11 = 21console.log(sum); //21console.log(num); //12//delete删除数组元素或对象的属性:var x = 3,arr = [1, 2],obj = {naem: 'jack'};delete x;console.log(x); //3,不能删除除数组和对象的其他数据类型的数据delete arr[0];console.log(arr[0]); //undefinedconsole.log(arr[1]); //2delete obj[name];console.log(obj.name); //undefined// 逻辑中断或短路引起代码不执行情况:var num1 = 10;var result1 = false && ++num1;var result2 = true || num1++;console.log(num1); //10//void(表达式),第一个案例不会被跳转,第二个案例会被跳转:<a href="javascript:void(0)">点击</a><a href="javascript:void(document.form.submit())">点击</a>//判断属性是否在对象中:var obj = {name: 'jack'};if ('name' in obj) {console.log('name属性存在obj中'); //name属性存在obj中,注意属性是字符串};</script>

赋值运算符:

+=、-=、*=、/=、%=、**=、<<=(左移位赋值,<<为左移位运算)

	<script>var num1 = 10;num1 += 1;console.log(num1); //11var num2 = 10;num2 -= 2;console.log(num2); //8var num3 = 10;num3 *= 2;console.log(num3); //20var num4 = 10;num4 /= 2;console.log(num4); //5var num5 = 10;num5 %= 7;console.log(num5); //3var num = 2;num **= 3;console.log(num);//8var a = 2;var b = 3;a <<= b; //a = a << b;console.log(a); //16</script>

比较运算符:

/>、<、>=、<=、== 、 ===、 != 、 !==

	<script>console.log(10 > 5); //truwconsole.log(10 < 5); //falseconsole.log(10 >= 5); //truwconsole.log(10 <= 5); //falseconsole.log('5' == 5); //trueconsole.log('5' === 5); //falseconsole.log('5' != 5); //falseconsole.log('5' !== 5); //true</script>

逻辑运算符:

&&–与,并且、||–或,或者、!–非,取反(逻辑中断情况:当&&前面的表达式是非 时,后面的表达式不再执行,当||前面的表达式为真时,后面的表达式不再执行),扩展二进制逻辑运算符:&(按位与)、~(按位非)、|(按位或)、^(按位异或)

	<script>//逻辑运算:console.log(false&&false);//falseconsole.log(true&&true);//trueconsole.log(false&&true);//falseconsole.log(true&&false);//falseconsole.log(false||false);//falseconsole.log(true||true);//trueconsole.log(false||true);//trueconsole.log(true||false);//trueconsole.log(111 && 222); //222console.log(111 || 222); //111console.log(111 != 222); //trueconsole.log(111 > 222 && true); //falseconsole.log(111 < 222 && false); //falseconsole.log(111 > 222 || true); //trueconsole.log(111 < 222 || false); //truevar num1 = 10;var num2 = 20;console.log(num1=num2&&5>6);//falseconsole.log(num2>10||5<0);//truevar num1 = 10;var sum = (num1+10)*5;console.log(sum);//100var result = (4 >= 6 || '人' != '狗' && !(12 * 2 == 144) && true);console.log(result);//truevar num =  10;var result2 = (5 == num / 2 &&(2 + 2*num).toString() === '22');console.log(result2);//true</script>

运算符优先级:
在这里插入图片描述
提示:本文图片等素材来源于网络,若有侵权,请发邮件至邮箱:810665436@qq.com联系笔者 删除。
笔者:苦海

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

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

相关文章

grootjs 简明教程

grootJs简明教程 mvvm框架也是解决的一类问题&#xff0c;在某些时候会提高生产效率&#xff1b; 经过接近一个月的努力&#xff0c;grootJs测试版终于发布了 grootJs是一个mvvm的框架&#xff0c;名字取 grass 和root 两个单词的组合&#xff0c;既“草根”之意。在创作的中…

流程控制介绍,顺序结构、分支结构、循环结构、Promise对象、throw语句、break和continue关键字

流程控制 流程控制&#xff1a;指代码的执行顺序&#xff0c;有三种方式&#xff1a;顺序结构、分支结构、循环结构 顺序结构&#xff1a; 代码从上到下&#xff0c;从左到右的执行顺序。 分支语句&#xff1a; if语句、if-else语句、if-else if-else语句、switch-case语…

javascript中数组、冒泡排序、函数及函数实参形参、arguments伪数组、异步函数等介绍

数组&#xff1a; 指一组有顺序的数据&#xff0c;其作用就是用来一次性存储多个数据。&#xff08;数组元素&#xff1a;数组中的每一个数据&#xff1b;数组长度&#xff1a;数据中元素的个数&#xff1b;数组索引&#xff1a;用来存储或访问数组中的数据&#xff0c;也叫下…

中文字串截取无乱码的问题

UTF-8中文截取函数在PHP中&#xff0c;substr()函数截取带有中文字符串的话&#xff0c;可能会出现乱码&#xff0c;这是因为中西文一个字节所占有的字节数不一样&#xff0c;而substr的长度参数是按照字节去算的&#xff0c;在GB2312编码时&#xff0c;一个中文占2个字节&…

javascript中作用域、全局作用域、局部作用域、隐式全局变量、块级作用域、作用域链、预解析

作用域 作用域指的是代码的作用范围&#xff0c;按照作用域划分变量可分为全局变量和局部变量&#xff1b;作用域可分为&#xff1a; 全局作用域&#xff1a; 指全局变量作用的范围&#xff1b;全局变量指的是通过var在函数外面声明的变量&#xff0c;在js中任何位置都可以使…

楼宇对讲门铃的芯片选型分析

目前很多的高层住宅都使用了对讲门铃了&#xff0c;在频繁使用中&#xff0c;门铃会出现的越来越多种类&#xff0c;下面我就简单的介绍会有用到的几款芯片. 语音通话芯片&#xff1a;D34018,D34118,D5020,D31101; D34018 单片电话机通话电路&#xff0c;合并了必 需的放大器…

easyui 布局自适应

最近在把以前写的一个项目改成用easyui做前端。过程中遇到了不少问题。其中一个就是datagrid不能很好的布局。想了好多办法都有局限。最后想到会不会是布局&#xff08;easyui-layout&#xff09;的问题&#xff0c;经过实验&#xff0c;最后问题解。 1&#xff1a;比如在项目中…

javascript中对象、JSON格式数据、创建对象的方式、数据类型分类及特点

对象 对象指&#xff1a;具体的一个实物&#xff0c;javascript中对象是指一组没有顺序的属性和方法的集合&#xff0c;所有的事物都是对象&#xff0c;例如&#xff1a;函数&#xff0c;数组&#xff0c;字符串等。属性指事物的特征&#xff0c;一般为名词表示&#xff1b;方…

在存储过程中编写正确的事务处理代码

在 SQL Server 中数据库事务处理是个重要的概念&#xff0c;也稍微有些不容易理解&#xff0c;很多 SQL 初学者编写的事务处理代码存往往存在漏洞&#xff0c; 本文介绍了三种不同的方法&#xff0c;举例说明了如何在存储过程事务处理中编写正确的代码。 在编写 SQL Server 事务…

javascript中内置对象简介、Array

内置对象&#xff1a; javascript的三种对象&#xff1a;1.内置对象—JavaScript自带的对象&#xff1b;2.自定义对象—自己定义构造函数创建对象&#xff1b;3.浏览器对象— BOM时候介绍&#xff0c;几个常用内置对象&#xff1a;Math Date String Array Object Array对象&a…

javascript中Date对象及方法

Date对象&#xff1a; 该对象呈现时间中的某个时刻。其本质是自1970年1月1日&#xff08;UTC&#xff09;起经过的毫秒数&#xff0c;相关属性的方法如下&#xff1a;&#xff08;如果Date对象中传入指定的时间&#xff0c;则以传入的指定时间返回相关数据&#xff0c;就不会以…

如何调优JVM

堆设置 -Xmx3550m&#xff1a;设置JVM最大堆内存 为3550M。-Xms3550m&#xff1a;设置JVM初始堆内存 为3550M。此值可以设置与-Xmx相同&#xff0c;以避免每次垃圾回收完成后JVM重新分配内存。-Xss128k&#xff1a;设置每个线程的栈 大小。JDK5.0以后每个线程栈大小为1M&#x…

javascript中encodeURL对象、Boolean对象、Function对象、globalThis对象、Infinity对象、isFinite对象、isNaN对象、JSON对象

encodeURI()对象&#xff1a; 用于对特殊字符进行编码&#xff0c;decodeURI()对象&#xff1a;将特殊字符进行解码&#xff0c;常用于URL地址编码中 <script>var url https://mozilla.org/?xшеллыvar urlEncode encodeURI(url);console.log(urlEncode); //http…

JAVA Web学习篇--Servlet

Servlet由来 做过BS项目的人都知道&#xff0c;浏览器可以依据HTML静态标记语言来显示各式各样的网页。可是假设我们须要在网页上完毕一些业务逻辑&#xff1a;比方登陆验证。或者说网页显示的内容在server的数据库中。假设是这样&#xff0c;除了负责显示的HTML标记之外&#…

javascript中Math对象及方法

Math对象&#xff1a; 其所有属性与方法都是静态的&#xff0c;其相关属性和方法如下&#xff1a; 继&#xff1a; 继&#xff1a; 提示&#xff1a;本文图片等素材来源于网络&#xff0c;若有侵权&#xff0c;请发邮件至邮箱&#xff1a;810665436qq.com联系笔者 删除。 笔者…

Linux crontab 命令格式与具体样例

基本格式 : *  *  *  *  *  command 分 时 日 月 周 命令 第1列表示分钟1&#xff5e;59 每分钟用*或者 */1表示 第2列表示小时1&#xff5e;23&#xff08;0表示0点&#xff09; 第3列表示日期1&#xff5e;31 第4列表示月份1&#xff5e;12 第5列标识号星期0…

javascript中NaN属性、null对象、Number对象、Object对象

NaN属性&#xff1a; 表示不是一个数字&#xff0c;是全局对象的属性&#xff0c;其初始值为NaN <script>console.log(NaN NaN); //false</script>null对象&#xff1a; 特指对象的值未设置 <script>console.log(null undefined); //trueconsole.log(nul…

网站建设的基本流程及服务端开发简介

服务端开发&#xff1a; 前面部分都是在介绍前端开发&#xff0c;接下来将介绍后端开发&#xff0c;这里采用php介绍&#xff0c;在本篇应当掌握编程能力&#xff0c;编程思想&#xff0c;解决问题的思路&#xff0c;熟悉网页开发&#xff0c;网站开发&#xff0c;应用开发的基…

Apache安装、配置、卸载

下载安装配置Apache&#xff1a; 1.将Apache官方下载地址&#xff1a;https://www.apachelounge.com/download/&#xff0c;复制到浏览器打开&#xff0c;选择系统支持的版本下载&#xff0c;如&#xff1a; 2.将下载好的压缩包剪贴到C盘根目录&#xff08;这里为了方便&…

企业级应用架构(一) 三层架构之解耦

前言 前段时间朋友拿了个网站给我&#xff0c;让我帮忙添加几个小功能&#xff0c;我爽快的答应了,但是当我打开源码&#xff0c;我瞬间就奔溃了&#xff0c;整个项目连最基本的三层框架也没有搭建&#xff0c;仅仅是封装了一个sqlhelp作为数据库的操作接口&#xff0c;项目中的…