一、JavaScript数值

1、整数和浮点数

根据国际标准 IEEE 754,64 位浮点数格式的 64 个二进制位中,第0 位到第 51 位储存有效数字部分,第 52 到第 62 位储存指数部分,第 63 位是符号位,0 表示正数,1 表示负数。

(图片:海码歌)

1)、 JavaScript 内部,所有数字都是以 64 位浮点数形式储存,即使整数也是如此。所以,1 与 1.0 是相等的,而且 1 加上 1.0 得到的还是一个整数, 自己会推导类型,不会像 JAVA 那样变成小数。

2)、尽可能不要使用小数比较,小数不精确

1 === 1.0 // true
1 + 1.0 // 2
0.1 + 0.2 === 0.3//false

整数二进制是除以 2 求余数 即 8421 码 ,小数:整数与小数部分分开,乘以 2,分数计数法。

5:

5*2=1 余 1

1/2=0 余 1

1

-->倒写 :101

0.3:

0.3*2=0.6

0.6*2=1.2

0.2*2=0.4

0.4*2=0.8

0.8*2=1.6

0.6*2=1.2….

2、表示法

基本:1.2 科学计数法: e 或 E

123e3 // 123000
123e-3 // 0.123

3、进制

使用字面量(literal)时,JavaScript 对整数提供四种进制的表示方法:十进制、十六进制、八进制、 2 进制。

十进制:没有前导 0。

八进制:有前导 0,且只用到 0-7 的七个阿拉伯数字,如果是 8-9 则表示十进制的 8-9。

十六进制:有前缀 0x 或 0X,用到十个阿拉伯数字,以及 a-f 和 A-F12 个英文字母。

二进制:有前缀 0b 或 0B,只用到 0 和 1 两个阿拉伯数字。

15

0xf // 15

017 // 15

0b1111 //15

09//9 -->无效的 8 进制

4、特殊数值

NaN:表示“非数字”(Not a Number),主要出现在将字符串解析成数字出错的场合。

1) NaN 不等于任何值,包括它本身,因为它不是一个值

2) NaN 与任何数(包括它自己)的运算,得到的都是 NaN。

3) isNaN 方法可以用来判断一个值是否为 NaN。

abc-1
0 / 0
NaN === NaN // false
NaN+1
isNaN(NaN) // true
isNaN(123) // false Infinity:无穷大
1 / -0 // -Infinity
1 / +0 // Infinity //isFinite 方法判断,是否为正常值。
isFinite(Infinity) // false
isFinite(-1) // true
isFinite(true) // true
isFinite(NaN) // false

  

5、使用 parseInt parseFloat Number 转换 ,

parseInt('123') // 123
parseInt('123px') //常用 123
parseFloat("3.14"); //3.14
Number(null) // 0

  

二、字符串 特殊字符

1、字符串为字符序列,多个字符 ,使用 '' 或 ""

'chrome'

"good"

"It's a long journey"

2、使用 + 拼接字符

'chrome' +'is' +'very' +'good'

3、特殊字符,转义 -->记住常用即可

\0 代表没有内容的字符(\u0000)

\n 换行符(\u000A)

\t 制表符(\u0009)

\' 单引号(\u0027)

\" 双引号(\u0022)

4、 Base64 转码

Base64 是一种编码方法,可以将任意字符转成可打印字符。使用这种编码方法,主要不是为了加密,而是为了不出现特殊字符,简化程序的处理。

btoa():字符串或二进制值转为 Base64 编码

atob():Base64 编码转为原来的编码

var string = 'Hello World!';

btoa(string) // "SGVsbG8gV29ybGQh"
atob('SGVsbG8gV29ybGQh') // "Hello World!" // 不适合中文,encodeURIComponent 中文必须先编码。
function b64Encode( str ) {
return btoa(unescape(encodeURIComponent( str )));
} function b64Decode( str ) {
return decodeURIComponent(escape(atob( str )));
} b64Encode('你好') // "5L2g5aW9"
b64Decode('5L2g5aW9') // "你好"

  

上海尚学堂java培训整理发布,更多请关注公众号 嗨码歌,谢谢

JavaScript数值和字符串、特殊字符的更多相关文章

  1. JS写法 数值与字符串的相互转换 取字符中的一部分显示 正则表达规则

    http://www.imooc.com/article/15885 正则表达规则 <script type="text/javascript"> </scrip ...

  2. JS规则 多样化的我(变量赋值)我们使用"="号给变量存储内容,你可以把任何东西存储在变量里,如数值、字符串、布尔值等,

    多样化的我(变量赋值) 我们可以把变量看做一个盒子,盒子用来存放物品,那如何在变量中存储内容呢? 我们使用"="号给变量存储内容,看下面的语句: var mynum = 5 ; / ...

  3. javascript正则表达式和字符串RegExp

    这篇文章主要介绍了javascript正则表达式和字符串RegExp and String(一)的相关资料,需要的朋友可以参考下     前言     正则表达式是javascript非常重要和常用的 ...

  4. 剑指 Offer 20. 表示数值的字符串 + 有限状态自动机

    剑指 Offer 20. 表示数值的字符串 Offer 20 常规解法: 题目解题思路:需要注意几种情况: 输入的字符串前后可能有任意多个空格,这是合法的. 正负号: (1)正负号只能出现一次. (2 ...

  5. JavaScript复习笔记——字符串

    String构造器可以使用new调用,也可以不使用,但是,这两种调用的结果也是完全不一样的.用new调用的时候,String作为构造器函数,创建字符串对象.不使用new的时候,String用作一个常规 ...

  6. 谈JavaScript组合拼接字符串的效率 --转载

    JavaScript组合拼接字符串的效率.在脚本开发过程中,经常会按照某个规则,组合拼接出一个大字符串进行输出.比如写脚本控件时控制整个控件的外观的HTML标签输出,比如AJAX里得到服务器端的回传值 ...

  7. javascript中对字符串的操作总结

    原文:javascript中对字符串的操作总结 没听过一句话吗?程序员的世界,不处理字符串就是处理数组.这是群里的一位前辈和我说的,显然这和我之前理解的DOM是javascript的核心的不同的,看了 ...

  8. SQL零星技术点:SQL中转换money类型数值转换为字符串问题

    --SQL中转换money类型数值转换为字符串问题,直接转换就转为两位了,所以需要做一下处理.具体请看下述sql实例. 1 create table #test(price money) insert ...

  9. javascript中的字符串对象和数组对象

    1.javascript的对象的概念 在javascript中,除了null和undefined以处,其他的数据类型都被定义成了对象 也可以用创建对象的方法定义变量,string,math,array ...

随机推荐

  1. qt ubutun各个版本下载地址

    http://download.qt.io/archive/qt/ http://mirrors.melbourne.co.uk/ubuntu-releases/

  2. MySQL版本问题导致的SQLException

    背景 ​ 学习使用 SpringCloud 时,使用 消费者 调用 生产者 时抛出 SQLException,持久层框架为 MyBatis,数据库为最新版本的 MySQL 版本如下: Server v ...

  3. python paramiko的使用介绍

    一: 使用paramiko #设置ssh连接的远程主机地址和端口t=paramiko.Transport((ip,port))#设置登录名和密码t.connect(username=username, ...

  4. 软件工程卷1 抽象与建模 (Dines Bjorner 著)

    I 开篇 1. 绪论 II 离散数学 2. 数 (已看) 3. 集合 4. 笛卡尔 5. 类型 6. 函数 7. λ演算 8. 代数 9. 数理逻辑 III 简单RSL 10. RSL中的原子类型和值 ...

  5. map函数怎么用咧↓↓↓

    Map是c++的一个标准容器,她提供了很好一对一的关系,在一些程序中建立一个map可以起到事半功倍的效果,总结了一些map基本简单实用的操作! 1. map最基本的构造函数:    map<st ...

  6. vue.config.js 配置 scss,less,sass全局配置 vuecli3

    module.exports = { /* 部署生产环境和开发环境下的URL:可对当前环境进行区分,baseUrl 从 Vue CLI 3.3 起已弃用,要使用publicPath */ public ...

  7. eclipse Referenced file contains errors (http://www.springframework.org/schema/context/spring-context-3.0.xsd)

        1.情景展示 spring配置文件报错信息如下: Referenced file contains errors (http://www.springframework.org/schema/ ...

  8. atlassian-confluence - docker安装

    一下内容在centos 7安装成功.一.安装docker 1.yum安装docker12 yum update # 更新yumyum install docker # yum安装docker 2.开启 ...

  9. builder模式实例

    package heapStark.blogCode.designPattern.builder; public class BaseBean { private int age; private S ...

  10. Azure容器监控部署(下)

    上文已经基本完成了环境的搭建,prometheus可以以https的方式从node_exporter和cAdvisor上pull到数据,访问grafana时也可以以https的方式访问,安全性得到了一 ...