JavaScript基础扫盲


null和undefined

null是一个是非来表示一个空对象的,故 typeof 的返回值是object

undefined字面义为未定义,当遇到声明一个变量,但没有赋值的时候,typeof的类型即为undefined

非十进制的表示方法

  • 十六进制:以0x开头
  • 八进制:以0开头
  • 二进制:以0b开头

进制转换如果以指定进制规定的格式书写是没有问题的

parseInt有平台兼容的问题

直接使用parseInt()解析070的字符串在chrome平台会得到70,而在firefox平台则会直接识别其为八进制的字符串,然后转换成数字56

parseInt()的第二个参数为进制,指定进制转换便可解决这个问题。


强制类型转换

强制类型转换,将一个类型转换为需要的数据类型

string

  • toString():由转换类型的内置方法进行转换,即 value.toString()便可以获取对应的字符串
  • String():系统方法,当toString()方法无法使用时(主要是在nullundefined类型面前失效),便可以使用,nullundefined将变等价转换成相同的字符中"null""undefined"


number

  • Number()

    • 字符串-->数字

      • 纯数字组成的字符串,将得到相应的整数值
      • 如果字符串由数字和非数字字符组成,将得到NaN
      • 如果字符串是一个空串或一个空格的字符串,则转换为0
    • 布尔-->数字:true值为1,false值为0
    • null-->数字:null转换将得到值 0
    • undefined-->数字:undefined转换得到值是NaN,且NaN参与的运算都会得NaN
  • parseInt():将字符串转换成整数,也可以按进制进行转换。parseFloat()仅从字符串开头识别,如果数字位于中间,将无法识别转换且返回NaN

  • parseFloat():在parseInt()的基础上支持识别小数点后的数字位。


boolean

Boolean():将其它数据类型转换为bool值

数字,除了0NaNfalse,其余数,包括负数,转换结果为true

字符串,空串转换为false,其余为true

nullundefined,转换结果均为false

对象转换为true


运算

通过运算符可以对一个值或者多个值进行运算,并得到相应的结果。

算术运算符

  • 任何值和NaN做任何运算都得NaN
  • 任何数值与字符串做加法运算都先转换成字符串,然后变成字符串相加,拼接处理
  • 任何数值与字符串做减乘除运算,都先将字符串转换成数值然后进行数学计算。

布尔运算符

相等运算符

  • ==!=:进行相等运算,会自动进行类型转换,当1 == ”1”就会返回true
  • ===!===:进行全等运算,不会自动进行类型转换,当类型都不一样的时候,条件全等就不成立,不全等成立,反之,亦然

javascript基础扫盲的更多相关文章

  1. JavaScript基础

    JavaScript基础 JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处 ...

  2. 一步步学习javascript基础篇(0):开篇索引

    索引: 一步步学习javascript基础篇(1):基本概念 一步步学习javascript基础篇(2):作用域和作用域链 一步步学习javascript基础篇(3):Object.Function等 ...

  3. 前端之JavaScript基础

    前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript历史 1992年Nombas开发出C ...

  4. 一步步学习javascript基础篇(3):Object、Function等引用类型

    我们在<一步步学习javascript基础篇(1):基本概念>中简单的介绍了五种基本数据类型Undefined.Null.Boolean.Number和String.今天我们主要介绍下复杂 ...

  5. Javascript基础回顾 之(三) 面向对象

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...

  6. Javascript基础回顾 之(二) 作用域

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...

  7. Javascript基础回顾 之(一) 类型

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...

  8. JavaScript 基础回顾——对象

    JavaScript是基于对象的解释性语言,全部数据都是对象.在 JavaScript 中并没有 class 的概念,但是可以通过对象和类的模拟来实现面向对象编程. 1.对象 在JavaScript中 ...

  9. javascript基础01

    javascript基础01 Javascript能做些什么? 给予页面灵魂,让页面可以动起来,包括动态的数据,动态的标签,动态的样式等等. 如实现到轮播图.拖拽.放大镜等,而动态的数据就好比不像没有 ...

随机推荐

  1. springmvc学习笔记(10)-springmvc注解开发之商品改动功能

    springmvc学习笔记(10)-springmvc注解开发之商品改动功能 标签: springmvc springmvc学习笔记10-springmvc注解开发之商品改动功能 需求 开发mappe ...

  2. 使用jQuery.makeArray() 将多种类型转换成JS原生Array

    jQuery.makeArray(obj)这个函数从名字上来看非常easy猜出它的用途:应该是用来将传入的对象转换成一个原生array 再看看官网上对它的解释:Convert an array-lik ...

  3. jeecg-easypoi-2.0.3版本号公布

    EasyPOI是在jeecg的poi模块基础上,继续开发独立出来的,能够说是2.0版本号,EasyPoi封装的目的和jeecg一致,争取让大家write less do more ,在这个思路上eas ...

  4. ios 得用代理反向传值

    应用场景:有时时候从界面A跳转到界面B,界面B在返回的时候须要将处理的结果传递给A. 实现思路:1,定义一个负责传值的协义,界面A拥有该协义属性,并实现该协义中的方法 2.界面B也拥有该协义属性(代理 ...

  5. USACO money packageDP

    裸0/1背包,就是从各种币种里面拿来凑足N元,求最多有多种方案.用dp[i][j]表示选前i个币种凑成j的方案数量 状态转移方程: dp[i][j] = dp[i- 1][j]    j < c ...

  6. BNU 13259.Story of Tomisu Ghost 分解质因子

    Story of Tomisu Ghost It is now 2150 AD and problem-setters are having a horrified time as the ghost ...

  7. Codeforces Round #402 D(二分)

                                                                                         D. String Game ...

  8. zoj--3870--Team Formation(位运算好题)

    Team Formation Time Limit: 3000MS   Memory Limit: 131072KB   64bit IO Format: %lld & %llu Submit ...

  9. poj3071Football(概率期望dp)

    Football Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5620   Accepted: 2868 Descript ...

  10. codechef MAY18 div2 部分题解

    T1 https://www.codechef.com/MAY18B/problems/RD19 刚开始zz了,其实很简单. 删除一个数不会使gcd变小,于是就只有0/1两种情况 T2 https:/ ...