转载请标明出处!
 

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

    samba是什么samba是什么?能干什么? samba 是基于SMB协议(ServerMessage Block,信息服务块)的开源软件,samba也可以是SMB协议的商标.SMB是一种Linux. ...

  2. ubuntu 使用阿里云 apt 源

    以下内容来自 https://opsx.alibaba.com/mirror Ubuntu对应的“帮助”信息 修改方式:打开 /et/apt/sources.list 将http://archive. ...

  3. BZOJ 3720 树分块

    借鉴了别人的代码-- //By SiriusRen #include <cmath> #include <cstdio> #include <cstring> #i ...

  4. Memcache使用场景

    session //php文件中 ini_set("session.save_handler", "memcache"); ini_set("sess ...

  5. 判断是否是Ajax请求

    Request.IsAjaxRequest()判断是否是ajax请求原理:Http协议上有个X-Requested-With:XML HttpRequest属性判断的 mvc后台通过Request可以 ...

  6. [ RESTful ] [ API ] 有用的資訊

    1. 淺談 REST 軟體架構風格 (Part.I) - 從了解 REST 到設計 RESTful https://blog.toright.com/posts/725/representationa ...

  7. 操作mysql操作数据库

    操作数据库 查询数据库:show databases: 增加数据库:create database student default character set uft-8:(设置默认字符集) 删除数据 ...

  8. bzoj 3028: 食物 生成函数_麦克劳林展开

    不管怎么求似乎都不太好求,我们试试生成函数.这个东西好神奇.生成函数的精华是两个生成函数相乘,对应 $x^{i}$ 前的系数表示取 $i$ 个时的方案数. 有时候,我们会将函数按等比数列求和公式进行压 ...

  9. luoguP1390 公约数的和 数学推导_双倍经验

    Code: #include <bits/stdc++.h> #include <tr1/unordered_map> #define setIO(s) freopen(s&q ...

  10. 百度api使用说明

    .初始化地图,并设置地图中心点 复制代码 https://www.cnblogs.com/zqzjs/p/5293698.html var map = new BMap.Map("allma ...