*在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. 比快更快——微软LightGBM

    LightGBM介绍 xgboost是一种优秀的boosting框架,但是在使用过程中,其训练耗时过长,内存占用比较大.微软在2016年推出了另外一种boosting框架--lightgbm,在不降低 ...

  2. 解决com.android.dex.DexException: Multiple dex files define Lcom/google/gson/JsonSerializer;

    我在开发Windows Azure的Mobile Service(隔天补上创建过程)的安卓客户端时,报出了com.android.dex.DexException: Multiple dex file ...

  3. jconsole远程监控logstash agent

    在logstash的jvm.options文件末尾添加: -Dcom.sun.management.jmxremote.port=9999   //指定jmx端口-Dcom.sun.managemen ...

  4. 跨平台网络通信与服务器框架 acl 3.2.0 发布,acl_cpp 是基于 acl 库的 C++ 库

    acl 3.2.0 版本发布了,acl 是 one advanced C/C++ library 的简称,主要包括网络通信库以及服务器框架库等功能,支持 Linux/Windows/Solaris/F ...

  5. 常用Linux网络命令

    TCP状态统计: netstat -anp TCP各个状态的连接数:netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a] ...

  6. PWN菜鸡入门之栈溢出(1)

    栈溢出 一.基本概念: 函数调用栈情况见链接 基本准备: bss段可执行检测: ​ gef➤ b main Breakpoint at . gef➤ r Starting program: /mnt/ ...

  7. vmware vSphere Data Protection 6.1 使用备份、恢复、报告

    一.6个选项卡说明 1.getting started 开始,提供VDP功能概述以及指向创建备份作业向导.恢复向导.报告选项卡的快速连接 2.backup 提供已计划备份作业的列表以及有关备份作业的详 ...

  8. 自己实现AOP,AOP实现的步骤分解

    自己实现简易的AOP 一.需求:自己实现AOP:1.0版本:在某个方法上加"@InOutLog"注解,那么执行到该方法时,方法的前面.后面会输出日志信息. [自己实现AOP 2.0 ...

  9. 建设DevOps统一运维监控平台,全面的系统监控 Zabbix VS Nagios VS Open-Falcon OR Prometheus

    前言 随着Devops.云计算.微服务.容器等理念的逐步落地和大力发展,机器越来越多,应用越来越多,服务越来越微,应用运行基础环境越来多样化,容器.虚拟机.物理机不一而足.面对动辄几百上千个虚拟机.容 ...

  10. Java并发之Semaphore和Exchanger工具类简单介绍

    一.Semaphore介绍 Semaphore意思为信号量,是用来控制同时访问特定资源的线程数数量.它的本质上其实也是一个共享锁.Semaphore可以用于做流量控制,特别是公用资源有限的应用场景.例 ...