转载请标明出处!
 

 
逻辑运算
 
 
 
      一门计算机语言,编程的核心在于逻辑思想,当我们在编写程序的时候,逻辑是否通顺,是能否正确写出程序的关键,可以说如果你掌握了逻辑,那么你就踏入了计算机编程的大门。
 
&&与 || 或 !否
 
逻辑 与 &&
 
var a=0,b=3;
 
alert(a==0&&b==3) //true;
 
alert(a==1&&b==3)//false;
 
他的返回值是布尔类型,当两个判断条件都成立的时候,那么整个语句返回true。如果有一个不成立那么返回值为false;
 
逻辑 或 ||
 
var a=0,b=3;
 
alert(a==1||b==3) //true;
 
alert(a==0||b==4)//true;
 
alert(a==10||b==40)//false;
 
他的返回值是布尔类型,当判断条件中有一个成立的时候,那么整个语句返回true。如果全部不成立那么返回值为false;
 
逻辑 否 !
 
var a=0,b=3;
 
alert(a!=1) //true;
 
alert(b!=3)//false;
 
 
他的返回值是布尔类型,当判断条件不成立的时候,那么整个语句返回true。如果成立那么返回值为false;
 
自增
 
 
 
 
      全国人民的干爹,但是在马云创业之前,他泯然众人,如果他不创业那?如果他不创建阿里那?他现在可能还是之前的样子。
 
      所以,在特定的时间点上,在经历过特殊的事情之后,人才会改变。
 
a++ ,a-- 他的返回值是 a本身,因为浏览器的解析顺序是从上到下从左到右,当我们读取到该语句的时候,首先被解析的就是变量a,他还没有进行任何运算,所以此时该语句的结果为变量a。
 
var a=1;
 
alert(a++);//1;
 
alert(a++);//????
 
++a ,--a 同理,因为解析顺序问题,当解析器
 
alert(++a);//2
 
 
NaN(一个自己都和自己不一样的特殊数字类型,表示不是数字的数字)
 
     
 
    alert(NaN==NaN)//false
 
    var a=0;
    var b;
    var c=a+b
 
    alert(c);
 
    //isNaN(num)函数,该函数判断num变量的值是否是NaN
 
    alert(isNaN(c));
 
 
 
Number()方法 toFixed()方法
 
Number对任意类型的数据进行强制类型转换,转换结果为数字。
 

alert(Number(true)); //1,Boolean 类型的 true 和 false 分别转换成 1 和 0

alert(Number(25)); //25,数值型直接返回

 
alert(Number(null)); //0,空对象返回 0
 
alert(Number(undefined)); //NaN,undefined 返回 NaN
 
var a=1.22222
 
a.toFixed(2)//返回值是1.22
 
a//1.22222
 
如果是对象,则在转换数字失败后,调用toString方法获得返回值;
 
var box = {
    toString : function () {
       return '123'; //可以改成 return 'abc' 查看效果
    }
};
alert(Number(box)); //123
 
创建对象(Object)类型
 
两种方式创建
 
1.var obj=new Object();
 
 2.var obj={
         
 }
 
 
parseInt()和parseFloat();
 
同样是强制转换数据,他们之间有什么不同那?
 
parseInt()该方法从左到右检测数字或字符串中第一个不为数字的字符,并把之前的所有进行返回,如果字符串中第一个就不为数字那么返回NaN;
 
例:
1.parseInt('123abc') a为第一个不为数字的字符;返回a之前的所有值,则该方法的返回值为123。
2.parseInt('abc123')a为第一个不为数字的字符,并在字符串开头位置,则判定该字符串无法转换为数字返回NaN;
 
parseFloat()该方法,检索数字或字符串后面第一个.后的不为数字的字符,并对之前所有的结果进行返回,如果第一个字符不为数字,那么返回NaN。
 
例:
1.parseFloat('123.123.123abc').第一个.后不为数字的字符那么,返回之前的字符,该方法返回123.123
 
 
程序的三大结构:
 
1.顺序结构
 
 
2.选择结构
 
    
3.循环结构
 
              
if(){}判断语句
 
 
if(true){
     
      //执行该语句    
 
}
 
if(false){
     
      //跳过该语句   
 
}
 
if(ture){ //当if括号中结果为true时执行语句1,否则执行语句2
 
     //语句1
 
}else{
 
     //语句2
}
 
if()括号中的东西我们通常叫它逻辑点。
 
一个奇葩问题
 
if(//在这个括号里会发生各种各样奇奇怪怪的事情)
 
if(1){
     
     alert('看我弹出来给你看')
 
}
 
感觉怪怪的:
 
1.if括号里填什么来着???
 
2.1是true么?
 
为什么会发生这样的事情那?在一些特定情况下,计算机会进行隐式类型转换。他和强制类型转换(Number)不一样,他不需要你做些什么,会自动对数据类型进行转换。
 
在 运算中,和if(括号中),会发生隐式类型转换。
 
1.运算中的隐式类型转换:
 
var a='1' ,b=2;
 
a+b=???
 
+运算符有两种含义,第一层含义是数学中的+运算,第二层含义是字符串拼接,优先运算字符串拼接,所以在检测到加好左右两边存在字符串的时候,会将运算符左右两边的数字都转换成字符串再进行运算。
 
a-b=???
 
除了+运算符具有两层含义以外,- * /只有数学意义,所以当进行- * /运算的时候默认会将运算符两侧的数据类型隐式转换为数字类型,再进行运算。
 
2.if(括号中的)隐式类型转换。
 
我们都知道,if括号中只需要布尔类型值。那么在if判断中,所有的数据类型都会被隐式转换为布尔类型。
 
if(非零数字都被转换成ture、非空字符串都转换成true),存在两条基础规则,其余规则在今后学习中慢慢发掘。
 
 
alert(1==true);//true
 
 
 
 
switch();
 
switch(语句){
    case 0:alert(1);
    break;
    case 2:alert(2);
    case 3:alert(3);     
    default:alert(10)
}
 
案例:成绩判定、显示星期几。
 
 
 
注意switch的应用场景(有多个确定值需要判断的时候);
 
注意case穿透,要加break语句(如果程序没有发现break语句,那么解析器会继续向下解析);

javascript系列-class2.javascript 基本使用的更多相关文章

  1. javaScript系列 [06]-javaScript和this

    在javaScript系列 [01]-javaScript函数基础这篇文章中我已经简单介绍了JavaScript语言在函数使用中this的指向问题,虽然篇幅不长,但其实最重要的部分已经讲清楚了,这篇文 ...

  2. javaScript系列 [03]-javaScript原型对象

    [03]-javaScript原型对象 引用: javaScript是一门基于原型的语言,它允许对象通过原型链引用另一个对象来构建对象中的复杂性,JavaScript使用原型链这种机制来实现动态代理. ...

  3. (一)我的Javascript系列:Javascript的面向对象旅程(上)

    今宵酒醒何处,杨柳岸,晓风残月 导引 我的JavaScript系列文章是我自己对JavaScript语言的感悟所撰写的系列文章.现在还没有写完.目前一共出了下面的系列: (三)我的JavaScript ...

  4. javaScript系列 [05]-javaScript和JSON

    本文输出和JSON有关的以下内容❐ JSON和javaScript❐ JSON的语法介绍❐ JSON的数据类型❐ JSON和XMLHTTPRequest❐ JSON的序列化和反序列化处理 1.1 JS ...

  5. (五)我的JavaScript系列:JavaScript的糟粕

    泪眼问花花不语,乱红飞过秋千去. JavaScript的糟粕 JavaScript语言是一门集精华与糟粕于一体的语言.在JavaScript: the good parts中,便集中讨论了关于精华与糟 ...

  6. javascript系列-Class1.JavaScript基础

    欢迎加入前端交流群来py:749539640 转载请标明出处!   JavaScript概述        一个页面分成三个部分,结构,样式,行为.               HTML代表了页面的结 ...

  7. 深入理解JavaScript系列:JavaScript的构成

    此篇文章不是干货类型,也算不上概念阐述,就是简单的进行一个思路上的整理. 要了解一样东西或者完成一件事情,首要的就是先要搞清楚他是什么.作为一个前端开发人员,JavaScript应该算作是最核心之一的 ...

  8. javaScript系列 [04]-javaScript的原型链

    [04]-javaScript的原型链 本文旨在花很少的篇幅讲清楚JavaScript语言中的原型链结构,很多朋友认为JavaScript中的原型链复杂难懂,其实不然,它们就像树上的一串猴子. 1.1 ...

  9. 【详解JavaScript系列】JavaScript之变量

    一  概述 本篇文章将讲解JavaScript中的变量,大致内容归结为: 1.变量定义 包括变量声明和变量初始化 2.变量种类 包括局部变量和全局变量 3.变量链式作用域及访问 二  内容 (一)变量 ...

随机推荐

  1. 10. Regular Expression Matching[H]正则表达式匹配

    题目 Given an input string(s) and a pattern(p), implement regular expression matching with support for ...

  2. 看似简单!解读C#程序员最易犯的7大错误

    编程时犯错是必然的,即使是一个很小的错误也可能会导致昂贵的代价,聪明的人善于从错误中汲取教训,尽量不再重复犯错,在这篇文章中,我将重点介绍C#开发人员最容易犯的7个错误. 格式化字符串 在C#编程中, ...

  3. px 与 pt

    px:pixel,像素,屏幕上显示的最小单位,用于网页设计,直观方便: pt:point,是一个标准的长度单位,1pt=1/72英寸,用于印刷业,非常简单易用: em:即%,在CSS中,1em=100 ...

  4. Thingworx新建Thing的数据库表变化

    为了在Thingworx的基础上建立统一的可视化平台,并且对软件产品具有自主控制权,不依赖于Thingworx软件(防止因Thingworx的升级.Bug导致的自主扩展功能受制),所以最近在研究Thi ...

  5. centos 7 防火墙配置

    centos 7里的防火墙使用的是firewall. 之前问过一个运维大牛,selinux的位置有点尴尬,说他们在工作中一般都会在第一时间关闭掉.我记得当时自己假设网站的时候就被这个坑了大半晚上.这个 ...

  6. vue项目 预览照片的插件 v-viewer

    查看图片主要使用的旋转.翻转.缩放.上下切换.键盘操作等功能都有. 1.首先是安装 npm install v-viewer --save 2.安装完在main.js里面引用(还要记得引用它的css样 ...

  7. HDU 2669 Romantic( 拓欧水 )

    链接:传送门 题意:求解方程 X * a + Y * b = 1 的一组最小非负 X 的解,如果无解输出 "sorry" 思路:裸 exgcd /***************** ...

  8. oracle数据库服务介绍

    共有7个服务,这七个服务的含义分别为: 1. Oracle ORCL VSS Writer Service:Oracle卷映射拷贝写入服务,VSS(Volume Shadow Copy Service ...

  9. Hdu 1429 胜利大逃亡(续) (bfs+状态压缩)

    这道题的钥匙只有10个,可以压成二进制 这里有有句非常关键的话 (k & door[x][y]) == door[x][y] 一开始以为只要(k & door[x][y]) ==1就可 ...

  10. C# 实现窗口程序winform像QQ一样靠近桌面边缘自动隐藏窗口

    实现原理: 实现这个功能的原理步骤如下: 1.判断窗体程序是否靠近桌面边缘: 2.获取桌面屏幕大小与窗体程序大小: 3.把窗体程序显示在桌面以外隐藏起来,预留部分窗体方便用户拉出程序: 4.判断鼠标是 ...