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. HDU 4405 Aeroplane chess (概率DP求期望)

    题意:有一个n个点的飞行棋,问从0点掷骰子(1~6)走到n点须要步数的期望 当中有m个跳跃a,b表示走到a点能够直接跳到b点. dp[ i ]表示从i点走到n点的期望,在正常情况下i点能够到走到i+1 ...

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

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

  3. STL_算法_逆转(reverse,reverse_copy)

    C++ Primer 学习中.. . 简单记录下我的学习过程 (代码为主) //全部容器适用 reverse(b,e)        //逆转区间数据 reverse_copy(b,e,b2) /** ...

  4. 每日算法之二十六:Substring with Concatenation of All Words

    变相的字符串匹配 给定一个字符串,然后再给定一组同样长度的单词列表,要求在字符串中查找满足下面条件的起始位置: 1)从这个位置開始包括单词列表中全部的单词.且每一个单词仅且必须出现一次. 2)在出现的 ...

  5. jquery选中表格的某行变色

    <tr ng-click="+"selectRow("+i+");"+" ng-mouseover="+"chan ...

  6. bzoj2935 [Poi1999]原始生物——欧拉回路

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2935 考察欧拉回路性质的题目呢: TJ:https://blog.csdn.net/u014 ...

  7. HP Unix vsftp服务配置

    HP Unix vsftp 服务配置: /opt/ssh/utils/ssh_chroot_setup.sh 运行脚本,会提示输入要建立的vsftp账号和要限制的家目录, 比如要限制的家目录为/Jia ...

  8. JPA实体关联关系,一对一以及转换器

    现有两张表 room (rid,name,address,floor) room_detail (rid,roomid,type) 需要创建房间实体,但是也要包含type属性 @Data //lamb ...

  9. MySQL实现递归查询

    DROP FUNCTION IF EXISTS queryChildrenCaseInfo;CREATE FUNCTION queryChildrenCaseInfo(cId INT)RETURNS ...

  10. Phoenix与Squirrel 是什么?

    不多说,直接上干货! 前言 Phoenix是HBase的开源SQL引擎. squirrel是windows上Phoneix可视化工具.  Phoenix的官网 http://phoenix.apach ...