转载请标明出处!
 

 
逻辑运算
 
 
 
      一门计算机语言,编程的核心在于逻辑思想,当我们在编写程序的时候,逻辑是否通顺,是能否正确写出程序的关键,可以说如果你掌握了逻辑,那么你就踏入了计算机编程的大门。
 
&&与 || 或 !否
 
逻辑 与 &&
 
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. angularjs1-2,作用域、代码压缩

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  2. HttpClient学习系列 -- 学习总结

    jar包: HttpClient 4.x版本 简要介绍 HttpComponents 包括 HttpCore包和HttpClient包 HttpClient:Http的执行http请求 Default ...

  3. phpmyadmin客户端多服务器配置

    修改libraries/config.default.php 545行,添加 $cfg['Servers']['2'] = $cfg['Servers'][$i];$cfg['Servers']['2 ...

  4. 云:VMware

    ylbtech-云:VMware VMware总部位于美国加州帕洛阿尔托 ,是全球云基础架构和移动商务解决方案厂商,提供基于VMware的解决方案,企业通过数据中心改造和公有云整合业务,借助企业安全转 ...

  5. BZOJ 2427 /HAOI 2010 软件安装 tarjan缩点+树形DP

    终于是道中文题了.... 当时考试的时候就考的这道题.... 果断GG. 思路: 因为有可能存在依赖环,所以呢 先要tarjan一遍 来缩点. 随后就进行一遍树形DP就好了.. x表示当前的节点.j表 ...

  6. 关于swift构造方法

    switf 中如果遇到这样的错,,,大概错误就是,"必须要调用父类的构造方法",,可是呢,,调用了super.init()  不就是调用了构造方法了吗? 结果上去一查,,结果一名外 ...

  7. DIV水平方向居中的几种方法

    一.使用margin: 1 #center0 { 2 background: red; 3 margin: 0 auto; 4 } 或者: margin: auto; 这样的前提是父盒子里没有其他盒子 ...

  8. jQuery对象与DOM对象的区别

    如何判断一个js对象是否一个DOM对象 我们在写js代码时有时需要判断某个对象是不是DOM对象,然后再进行后续的操作,这里我给出一种兼容各大浏览器,同时又算是比较稳妥的一种方法. 要判断一个对象是否D ...

  9. Typescript 模拟实现 多继承

    class Animal{ eat():void{ alert("animal eat"); } } class Mamal extends Animal{ breathe() : ...

  10. ZBrush中Layer层笔刷介绍

    本文我们来介绍ZBrush®中的Layer层笔刷,该笔刷是一种类似梯田效果的笔刷,常用来制作鳞甲和花纹图腾.他还可以用一个固定的数值抬高或降低模型的表面,当笔刷在重合时,笔画重叠部分不会再次位移,这使 ...