*在js中不同类型之间的运算,所得到结果的类型也会有所变化:
string + number = string
string + boolean = string
string + undefiend = string
number + boolean = number
number + undefiend = NaN
boolean + undefiend = NaN
总结一下就是:
所有与string类型数据进行运算得到的结果一定是字符类型;
与number类型数据进行运算时,会将其它非string类型数据转换为number,若转换成功,则结果为number,转换不成功则为:NaN;
而boolean类型数据进行运算时,会将自身转换为number类型,再与其它的数据进行运算,其运算规则与number一致;
*在js中有一个用来判断数据是否是数字的函数:isNaN(数据) 结果为ture 则不是数字 为false,则是数字
*在js中同样有数据类型的强制转换
toString() 将任何数据转换为字符串
用法:数据.toString()
parseInt() 将数据转换为整型的number类型
用法:parseInt(数据)
规则:从左到右进行转换,当遇到一个不为数字字符时就停止转换
parseFloat() 将数据转换为浮点型的number类型
用法:parseFloat(数据)
规则:从左到右进行转换,当遇到一个不为数字和小数点的字符时就停止转换,并且在小数点后又遇到小数点也停止转换
Number() 将数据转换为number型
用法:Number(数据)
规则:只要包含了非数字字符,返回NaN

1.关于逻辑与、逻辑或的短路:
逻辑与:只要一个条件为假,整个表达式的值都为假,并且不会去判断后面的条件
逻辑或:只要第一个条件为真,整个表达式的值为真,并且不会去判断后面的条件

2.关于小数数值的精确度问题

3.关于位运算符
按位与:将操作数转换为二进制,进行运算的两位数同时为1,结果才为1
按位或:将操作数转换为二进制,进行运算的两位数有一个为1,结果就为1
按位异或:进行比较的数据只有一个为1时

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>js运算符</title>
</head>
<body>
<script type="text/javascript">
/*1.关于逻辑与、逻辑或的短路:
逻辑与:只要一个条件为假,整个表达式的值都为假,并且不会去判断后面的条件
逻辑或:只要第一个条件为真,整个表达式的值为真,并且不会去判断后面的条件*/
// 1.1价格打折:用户输入消费金额,如果消费的金额>=100,享受八折,输出实际付费金额
var price = prompt("请输入消费金额:");
price >= && (price = price *0.8);//逻辑与短路
console.log(price);
// 1.2请用户输入一段留言:如果输入了,就输出留言的内容,否则就输出:“主人很懒
// 空字符串 可以当false使用
// undefined、0、0.0、""
var msg = prompt("请输入留言:");
var result = msg || ("主人很懒什么都没留下");//逻辑或短路
console.log(result);
// 2.关于精确度问题
// 买菜找零
var change = - 1.6;
console.log("找零:"+ change);
// 四舍五入解决精确度误差,toFixed(n) n为保留几位小数
change = change.toFixed();
console.log("四舍五入后:"+ change);
/*3.关于位运算符
按位与:将操作数转换为二进制,进行运算的两位数同时为1,结果才为1
按位或:将操作数转换为二进制,进行运算的两位数有一个为1,结果就为1
按位异或:进行比较的数据只有一个为1时 值才为1*/
// 3.1判断数字与1做按位与,最后一位为1为奇数,0为偶数
console.log(( & ) == );//ture偶数
console.log(( & ) == );//false奇数
// 3.2按位或:向下取整,将数据转换成二进制,且小数会被转换为整数
var num3 = 6.5;
console.log(num3 | );//将6.5转换为整数6,然后与0按位或 最后的结果是6 // 3.3交换两个数的值
var num1 = ,num2 = ;
num1 = num1 ^ num2;
num2 = num1 ^ num2;
num1 = num1 ^ num2;
console.log(num1,num2);
</script>
</body>
</html>

(*注意:运行代码时,需要将暂时不验证的代码注释掉,或者将需要验证的到吗复制粘贴到其它文件中进行运行)

JavaScript知识点---->运算规则与运算(逻辑、位)的更多相关文章

  1. JavaScript知识点总结

    JavaScript学习总结1.JavaScript是作用于网络和HTML的一个编程语言.2.JavaScript代码必须放在<script></script>标签之间,Jav ...

  2. C# 2进制、8进制、10进制、16进制...各种进制间的转换(三) 数值运算和位运算

    一.数值运算 各进制的数值计算很简单,把各进制数转换成 十进制数进行计算,然后再转换成原类型即可. 举例 :二进制之间的加法 /// <summary> /// 二进制之间的加法 /// ...

  3. javascript知识点积累

    8年javascript知识点积累   08年毕业就开始接触javascript,当时是做asp.net发现很多功能用asp.net控件解决不了,比如checkbox单选,全选问题,自动计算总价问题, ...

  4. JavaScript知识点整理(一)

    JavaScript知识点(一)包括 数据类型.表达式和运算符.语句.对象.数组. 一.数据类型 1) js中6种数据类型:弱类型特性 5种原始类型:number(数字).string(字符串).bo ...

  5. Android实训案例(一)——计算器的运算逻辑

    Android实训案例(一)--计算器的运算逻辑 应一个朋友的邀请,叫我写一个计算器,开始觉得,就一个计算器嘛,很简单的,但是写着写着发现自己写出来的逻辑真不严谨,于是搜索了一下,看到mk(没有打广告 ...

  6. JavaScript中Float类型保留两位小数

    JavaScript中Float类型保留两位小数 核心方法: num:要操作的数字     size:要保留的位数 parseFloat(num).toFixed(size); 实现代码如下:var  ...

  7. Javascript:必须知道的Javascript知识点之“单线程事件驱动”

    heiboard: Javascript:必须知道的Javascript知识点之“单线程事件驱动”

  8. golang中算数运算、位运算、逻辑运算、赋值运算常用方法

    package main import "fmt" var a = 21.0 var b = 5.0 //var c float64 func main() { Arithmeti ...

  9. Javascript知识点记录(三)设计模式

    Javascript设计模式记录,这个方面确实是没写过,工作中也没有用到js设计模式的地方. prototype与面向对象取舍 使用prototype原型继承和使用面向对象,都可以实现闭包的效果.那么 ...

随机推荐

  1. 【Qt】一劳永逸解决UAC问题(修改mkspecs\win32-msvc2012\qmake.conf)

    如果你的程序跑在一个开启了UAC保护的系统中,而你的程序又没有"盾牌"的话,程序总是会受到各种阻挠的,比如读写文件,写注册表等. 有了"盾牌"的话就不会出现一些 ...

  2. MASM 命令行编译方法

    假设有一个t est.asm ,一个test.rc 可以在CMD里这么编译: ml /c /coff test.asm rc test.rc link /subsystem:windows test. ...

  3. c# 可移动可改变大小的控件

    因为业务需要,百度了个可移动可改变大小的控件,然后自己修改了下,功能类似vs的设计面板中的功能差不多,可拖拽,改变大小 拖动的 public class MoveControl { #region 自 ...

  4. mysql远程表链接

    FEDERATED简介 FEDERATED存储引擎是访问远程数据库中的表,在平时开发中可以用此特性来访问远程库中的参数表之类的,还是非常方便的.使用时直接在本地构建一个federated表来链接远程数 ...

  5. 解释一下,知乎上关于C语言奇技淫巧最火的回答。

    前几天逛知乎,碰巧发现一个很火的问题. “C 语言有什么奇技淫巧?”虽然问题本身没有什么特殊的地方,但是网友的回答却是非常幽默. 下面就让我们一起来分析一下,被赞最多的答案“C 语言运算符 趋向于‘- ...

  6. 3022Java_运算

    运算 1.运算符分类 算术运算符 二元运算符 +,-,*,/,% 一元运算符 ++,-- 赋值运算符   = 扩展运算符 +=,-=,*=,/= 关系运算符 >,<,>=,<= ...

  7. Metasploit渗透测试

    原创博客,转载请注出处! 学习笔记 参考书籍<Metasploit渗透测试指南(修订版)> 经过多日学习,初步掌握metasploit基本参数和使用方法,现进行渗透测试实践 靶机IP:16 ...

  8. 《菜鸟也要学会C》-和大家聊一聊

    简介 为什么要出本系列作品? 怎么学好C? 学完这套课程后,我的编程会怎么样? 1.1为什么要出本系列作品? 随着大部分人喜欢编程,大部分人都有一个毛病,就是想要急切的学完编程.其实这种思想是错误的, ...

  9. 视频私有云实战:基于Docker构建点播私有云平台

    私有云是为一个客户单独使用而构建的,因而提供对数据.安全性和服务质量的最有效控制.前置条件是客户拥有基础设施,并可以使用基础设施在其上部署应用程序.其核心属性是专有的资源.本篇文章将会结合网易云信的实 ...

  10. 【Linux】一步一步学Linux——VMware虚拟机三种网络模式详解(07)

    目录 00. 目录 01. 虚拟网络连接组件 02. 常见网络连接配置 03. 桥接模式 04. NAT 模式 05. 仅主机模式 06. 自定义模式 07. 附录 00. 目录 @ 01. 虚拟网络 ...