一、概念

  

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>js的基本语法2</title>
<script type="text/javascript">
/*1、进制转换 16进制0x开头 如0xff=255(十进制); 8进制是0开头 070=56(十进制)
* 2进制0b开头 0b10=2(十进制) 兼容性不好
* 像“070”这样的字符串,有些浏览器会当八进制有些当十进制解析,所以可以在parseInt传参数,指定进制的类型
*2、将其他数据类型转成布尔值。
* 数字-->布尔 0和null是false,其他都是(正、负数)true
* 字符串-->布尔 空串是false 其余都是true
* null和undefined、object -->布尔 都是true
*/
var a="070";
//console.log(parseInt(a,8));//这里第2个参数的8就是让浏览器指定8进制解析
var b=123;
//console.log(Boolean(a)); /*运算符(如typeof 获取值得类型) 通过对一个或多个值进行运算,并返回获取运算结果
* 1、typeof 会将值的类型以string 字符串的形式返回 如果typeof(34) 的返回类型就是string
* 2、+ - * / 加减乘除 %取余 不改变返回值类型 对于非number类型的自动转存number类型后再运算
* 【注】两个字符串相加时或其他任何类型(先转成字符串类型)加字符串类型时 “+” 做连接符
* 利用让任意数据加空串也可将其他数据类型转成字符串类型 如:var a=123+"";
* 是从左到右计算的 1+2+"3" 输出 33; "1"+2+3 输出 123
* 【注】100-"1"输出99 除了+可能做连接符 其余的都是把其他类型转成number类型的数
* 10/3的结果不是Java中3 而是就算出3.33333.... (大约16位)
*
* 3、一元运算符
* + -跟数学中一样 对于其他类型先转成数字类型 如var a= +"18" 输出18 数字类型的
* a++ 、 ++a都能自增1,结果一样变量a都能加1 a=a+1;
* a是变量 a++是个表达式,也有自己的值,单独使用时,功能一模一样,都是让a的值增加1;
* 不同的是与赋值号“=”一起使用时,y=++a表示先将a的值增加1后,再把值赋给y;
* y=a++表示先把a的值给y,a自己再增加1.
* a++: a++的值等于原变量的值(自增前的值) 等于先赋值后自增
* ++a: ++a的值等于原变量的新值(自增后的值) 等于先自增后赋值
*
* */
var x=10;
y=x++;
console.log("x= "+x);
console.log("y= "+y); var m=10;
n=++m;
console.log("m= "+m);
console.log("n= "+n); /*4、逻辑运算符
* 与(&&) 全真为真,“短路与”,前边是假就不会去判断后边的真假
* 或(||) 全假为假,“短路或”,前边是真就不会看后边的真假
* 非(!)
* 【注意】对于非布尔值会先将其转成布尔值再去运算,然后返回原值,不是true false
* (1)与(找假): 若第一个是真,必然返回第二个
* 若第一个为假,必然返回第一个
* (2)或(找真): 若第一个真,则直接返回第一个值
* 若第一个假,则直接返回第二个值
* 如var a=1&&2 输出2,不是true * */
var e=(1==2)&&(2==2);
console.log(e);
/*5、赋值运算符 =、+=(是一个运算符,中间不能加空格,如a=a+5简写成a+=5)、-=、*=、/=
* %=(如 a%=5等价于 a=a%5)
*
*6、关系运算符 > 、< 、>=、<=、==(恒等于) 、!=(不等于) ===(全等于) !==(不全等于)
* 如果关系成立返回真 不成立返回假 若是非数字则先转成数字再比较 总之,以数字为基准
* 如果两边都是字符串,不会转成数字,而是比较Unicode编码(逐位比较,类似于单词本)
* ---先比较第1位若有结果不会往下看 如字符串"11"<"5" 输出true 因为字符1的小于字符5的编码 不会看第2位
* ---若有第1位相同,比较第2位,以此类推
* ---比较字符串型的数字时要转型 如"1234"< +"5" 加号就相当于把字符串5转型成数值型
* 任何值和NaN(常见于字符串,字符串变成NaN)比较都是false
* var a=(5>3); 返回true
* "123"===123 类型不同直接返回假 不做类型转换 同理不全等直接返回真
*
* 7、输出Unicode 编码中的字符 前边加个\u后边跟4位16进制编码
* 在网页中显示使用 &#编码(这里的编码需要是10进制)
*
* 8、条件运算符(也叫三元运算符)
* ? : 先对条件表达式求值 若该值为真,执行语句1(前边),并返回执行结果;反之执行语句2
* max=(3>2)?3:2
* 9、优先级(跟数学中差不多) 记得加括号即可
* 优先级一样,则从左到右
*/
console.log("\u2620");
var max=(10>8)?10:8
console.log(max);
var a=12,b=15,c=8;
var max2=(a>b?a:b) > c?((a>b?a:b)):c;
console.log(max2) </script>
</head>
<body>
&#9760
</body>
</html>

最新文章

  1. jquery版滑块导航栏
  2. CURL in windows
  3. Android应用开发SharedPreferences存储数据的使用方法
  4. http学习笔记(二)—— 嘿!伙计,你在哪?(URL)
  5. atitit.数据验证--db数据库数据验证约束
  6. 使用Android Annotations开发
  7. mongodb(二) 安装和使用
  8. groovy-集合
  9. C#自定义控件背景色透明的方法
  10. arcsde service(esri_sde)服务启动后又停止
  11. sql行转列和列转行(转)
  12. IT职场生存法则
  13. HowTo: SVN undo add without reverting local changes
  14. VC禁止在任务管理器中结束本进程
  15. c语音中打印参数调用层级即call stack, call trace
  16. Weex 样式
  17. Linux方面收藏的一点儿资料
  18. angularJS ng-change错误的解决方案
  19. 【Android Developers Training】 91. 解决云储存冲突
  20. C++中的继承(3)作用域与重定义,赋值兼容规则

热门文章

  1. python List 常用方法
  2. 基于flask的可视化动漫分析网站【python入门必学】
  3. Python---面向对象---龟鱼游戏
  4. codeforces 819B - Mister B and PR Shifts(思维)
  5. 配置服务器(anaconda + jupyter + R)
  6. 【BZOJ1132】Tro(叉积)
  7. 洛谷P1982 小朋友的数字——题解
  8. 转: Github上关于iOS的各种开源项目集合
  9. Java操作数据库之JDBC增删改查
  10. javascript处理json字符串