JavaScript 入门·JavaScript 具有全范围的运算符


Posted in Javascript onOctober 01, 2007

复合赋值运算符

运算符 符号
加法 +=
按位与 &=
按位或 |=
按位异或 ^=
除法 /=
左移
取模 %=
乘法 *=
右移 >>=
减法 -=
无符号右移 >>>=

要求

版本信息

条件(三目)运算符 (?:)

根据条件执行两个语句中的其中一个。

test ? 语句1 : 语句2

参数

test

任何 Boolean 表达式。

语句1

testtrue 时执行的语句。可以是复合语句。

语句2

testfalse 时执行的语句。可以是复合语句。

说明

?: 运算符是 if...else 语句的快捷方式。它通常被用作较大表达式的一部分,而在此处使用 if...else 语句是不协调的。例如:

var now = new Date();
var greeting = "Good" + ((now.getHours() > 17) ? " evening." : " day.");

在该例子中,如果是 6pm 以后,则创建一个包含 "Good evening." 的字符串。使用 if...else 语句的等效代码如下:

var now = new Date();
var greeting = "Good";
if (now.getHours() > 17)
   greeting += " evening.";
else
   greeting += " day.";

要求

版本 1

请参阅

if...else 语句 | 运算符优先级 | 运算符总结

delete 运算符

从对象中删除一个属性,或从数组中删除一个元素。

delete expression

expression 参数是一个有效的 JScript 表达式,通常是一个属性名或数组元素。

说明

如果 expression 的结果是一个对象,且在 expression 中指定的属性存在,而该对象又不允许它被删除,则返回 false

在所有其他情况下,返回 true

要求

版本 3

请参阅

运算符优先级 | 运算符总结

除法赋值运算符 (/=)

变量值除以表达式值,并将结果赋给该变量。

result /= expression

参数

result

任何数值变量。

expression

任何数值表达式。

说明

使用 /= 运算符和使用下面的语句是等效的:

result = result / expression

要求

版本 1

请参阅

/ 运算符 | 运算符优先级 | 运算符总结

除法运算符 (/)

将两个表达式的值相除。

result = number1 / number2

参数

result

任何数值变量。

number1

任何数值表达式。

number2

任何数值表达式。

要求

版本 1

请参阅

/= 运算符 | 运算符优先级 | 运算符总结

in 运算符

测试对象中是否存在该属性。

result = property in object

参数

result

必选项。任意变量。

property

必选项。相当于字符串表达式的一个表达式。

object

必选项。任意对象。

说明

in 操作检查对象中是否有名为 property 的属性。也可以检查对象的原型,以便知道该属性是否为原型链的一部分。

要求

版本 1

请参阅

运算符优先级 | 运算符总结

递增 (++) 和递减 (--) 运算符

变量值递增一或递减一。

语法 1

result = ++variable
result = --variable
result = variable++

result = variable--

语法 2

++variable
--variable
variable++

variable--

参数

result

任何变量。

variable

任何变量。

说明

递增和递减运算符,是修改存在变量中的值的快捷方式。包含其中一个这种运算符的表达式的值,依赖于该运算符是在变量前面还是在变量后面:

var j, k;
k = 2;
j = ++k;

因为递增发生在表达式被求值前,所以值 3 赋给了 j

和下面的例子对照:

var j, k;
k = 2;
j = k++;

在此,因为递增发生在表达式被求值后,所以值 2 赋给了 j。

JavaScript 具有全范围的运算符,包括算术、逻辑、位以及赋值运算符。此外还有其他一些运算符。

 计算 逻辑 位运算 赋值 杂项
 描述 符号 
 负值 -
逻辑非 !
按位取反 ~
赋值 =
删除 delete
 递增 ++
小于 <
按位左移 <<
运算赋值 oP= typeof
运算符 
 递减 --
大于 >
按位右移 >>
void 运算符 void
 乘法 *
小于等于 <=
无符号右移 >>>
 除法 /
大于等于 >=
按位与 &
 取模运算 %
等于 ==
按位异或 ^
 加法 +
不等于 !=
按位或 |
 减法 -
逻辑与 &&
  逻辑或 ||
  条件(三元运算符) ?:
  逗号 ,
  恒等 ===
  不恒等 !==

 运算符优先极
 JavaScript 中的运算符是按照一个特定的顺序来求值的。这个顺序就是运算符的优先级。下表按从最高到最低的优先级列出了这些运算符。处于同一行中的运算符按从左至右的顺序求值。

 运算符 描述
 . [] () 字段访问、数组下标以及函数调用
 ++ -- - ~ ! typeof new void delete 一元运算符、返回数据类型、对象创建、未定义值
 * / % 乘法、除法、取模
 + - + 加法、减法、字符串连接
 << >> >>> 移位
 < <= > >= 小于、小于等于、大于、大于等于 
 = !=   ===   !== 等于、不等于、恒等、不恒等
 & 按位与
 ^ 按位异或
 | 按位或
 && 逻辑与
 || 逻辑或
 ?: 条件
 = oP= 赋值、运算赋值
 , 多重求值

 圆括号可用来改变求值顺序。圆括号中的表达式应在其用于语句的其余部分之前全部被求值。

 具有较高优先级的运算符将在具有较低优先级的运算符之前被求值。例如:

 z = 78 * (96 + 3 + 45)

 在该表达式中有五个运算符: =, *, (), +, 以及 +。根据优先级,它们将按下面的顺序求值: (), *, +, +, =。

 首先对圆括号内的表达式求值:其中有两个加法运算符,它们具有相同的优先级:96 和 3 相加,然后再将它们的和与 45 相加,得到的结果为 144。
 然后是乘法运算: 78 和 144 相乘,得到结果为 11232。
 最后是赋值运算:将 11232 赋给 z。

Javascript 相关文章推荐
浅谈Javascript鼠标和滚轮事件
Jun 27 Javascript
基于Javascript实现返回顶部按钮
Feb 29 Javascript
Vue.js动态组件解析
Sep 09 Javascript
vue.js中指令Directives详解
Mar 20 Javascript
微信小程序canvas写字板效果及实例
Jun 15 Javascript
微信小程序对接七牛云存储的方法
Jul 30 Javascript
微信小程序自定义模态对话框实例详解
Aug 16 Javascript
select标签设置默认选中的选项方法
Mar 02 Javascript
webpack打包非模块化js的方法
Oct 24 Javascript
vue导航栏部分的动态渲染实例
Nov 01 Javascript
微信小程序顶部导航栏可滑动并选中放大
Dec 05 Javascript
Vue实现下拉加载更多
May 09 Vue.js
javascript入门·动态的时钟,显示完整的一些方法,新年倒计时
Oct 01 #Javascript
javascript入门·图片对象(无刷新变换图片)\滚动图像
Oct 01 #Javascript
javascript入门·对象属性方法大总结
Oct 01 #Javascript
JS创建优美的页面滑动块效果 - Glider.js
Sep 27 #Javascript
[HTML/CSS/Javascript]WWTJS
Sep 25 #Javascript
奇妙的js
Sep 24 #Javascript
让getElementsByName适应IE和firefox的方法
Sep 24 #Javascript
You might like
在PHP中使用灵巧的体系结构
2006/10/09 PHP
php 代码优化之经典示例
2011/03/24 PHP
phpMyAdmin自动登录和取消自动登录的配置方法
2014/05/12 PHP
用JavaScript实现仿Windows关机效果
2007/03/10 Javascript
jQuery function的正确书写方法
2013/08/02 Javascript
js onmousewheel事件多次触发问题解决方法
2014/10/17 Javascript
javascript转换静态图片,增加粒子动画效果
2015/05/28 Javascript
在JavaScript中处理时间之getHours()方法的使用
2015/06/10 Javascript
jquery.map()方法的使用详解
2015/07/09 Javascript
js实现表单多按钮提交action的处理方法
2015/10/24 Javascript
使用jQuery UI库开发Web界面的简单入门指引
2016/04/22 Javascript
JS实现n秒后自动跳转的两种方法
2020/11/30 Javascript
js实现浏览器倒计时跳转页面效果
2016/08/12 Javascript
修改Jquery Dialog 位置的实现方法
2016/08/26 Javascript
javascript self对象使用详解
2016/10/18 Javascript
详解vuex之store拆分即多模块状态管理(modules)篇
2018/11/13 Javascript
解决JQuery的ajax函数执行失败alert函数弹框一闪而过问题
2019/04/10 jQuery
解决vue项目F5刷新mounted里的函数不执行问题
2019/11/05 Javascript
小程序跨页面交互的作用与方法详解
2020/01/07 Javascript
Vue执行方法,方法获取data值,设置data值,方法传值操作
2020/08/05 Javascript
Python获取远程文件大小的函数代码分享
2014/05/13 Python
在Python的Flask框架下收发电子邮件的教程
2015/04/21 Python
简单介绍Python下自己编写web框架的一些要点
2015/04/29 Python
Python 爬虫的工具列表大全
2016/01/31 Python
Python 自动刷博客浏览量实例代码
2017/06/14 Python
解决python os.mkdir创建目录失败的问题
2018/10/16 Python
python使用pipeline批量读写redis的方法
2019/02/18 Python
python在新的图片窗口显示图片(图像)的方法
2019/07/11 Python
django rest framework 实现用户登录认证详解
2019/07/29 Python
详解django实现自定义manage命令的扩展
2019/08/13 Python
关于jupyter打开之后不能直接跳转到浏览器的解决方式
2020/04/13 Python
详解如何通过H5(浏览器/WebView/其他)唤起本地app
2017/12/11 HTML / CSS
致跳远运动员加油稿
2014/02/11 职场文书
4s店市场专员岗位职责
2014/04/09 职场文书
办公室主任个人总结
2015/02/28 职场文书
教师节校长致辞
2015/07/31 职场文书