Javascript高级程序设计第五章 | ch5 | 阅读笔记
基本引用类型
Date
- 在不给定时间的情况下创建Date实例,创建的对象将保存当前的日期和时间。
- 要基于其他时间创建Date对象,必须传入其毫秒时表示
- Date.parse()
- 月/日/年(5/21/2022)
- 月名 日, 年(May 21, 2022)
- 周几 月名 日 年 时:分:秒 时区(Tue May 23 2022 00:00:00 GMT-0700)
- YYYY-MM-DDTHH:mm:ss.sssZ(2019-05-23T00:00:00只适用于兼容ES5的实现)
- Date.UTC(年,月,日,时,分,秒):返回日期的毫秒表示
- Date.parse()
继承的方法
日期格式化方法
日期/时间组件方法
RegExp
原始值包装类型
Boolean
- Boolean会重写valueOf()方法,返回原始值true 或者 false。toString()方法被调用时也会被覆盖
let falseObj = new Boolean(false);
let result = falseObj && true; // 所有对象在bool表达式中都会转换为true
console.log(result); // true
let falseVal = false;
result = falseVal && true;
console.log(result); // false
Number
- 重写了valueOF() toLocalString() toString()
- toFixed() 0~20个小数位
- 科学计数法:toExponential()
- 返回最合理的输出结果:toPrecision()
- isInteger()是否为整数
String
常用方法:
- normalize()方法
- 字符串操作方法
- slice()
- substr()
- substring()
- 第一个参数表示字符串开始位置,第二个参数表示结束位置
- 对于substr()而言,第二个参数表示截取的子字符数量
- 字符串位置方法
- indexOf(str, idx)
- lastIndexOf(str, idx)
- 在字符串中搜索传入的字符串,并返回位置,没找到则返回-1
- indexOf从头开始查找
- lastIndexOf从末尾开始
- 第二个参数的意思是从指定位置开始查找
- 字符串包含方法
- startsWith(str):是否以str开头
- endWith(str):是否以str结尾
- includes(str):是否包含str
- 搜索传入的字符串,并返回一个bool值
- trim()方法:创建字符串的副本,删除前后所有的空格,再返回结果
- repeat(times)方法:返回将字符串拼接times次之后的结果
- padStart(len, str)和padEnd(len, str)方法
- 将字符串用指定str拼接成长度为len的字符串
- padStart是在开头填充
- padEnd是在结尾填充
- 字符串迭代器与解构
let message = 'abc';
let stringIterator = message[Symbol.iterator]();
console.log(stringIterator.next()); // {value: 'a', done: false}
for (const c of message) console.log(c); // a b c
console.log([...message]); // ['a', 'b', 'c']
- 字符串大小写转换
- toLowerCase()
- toLocaleLowerCase()
- toUpperCase()
- toLocaleUpperCase()
- local: 针对特对地区实现,如果不知道代码涉及什么语言,最后使用local
- 字符串模板方法
- match(): 本质上和RegExp对象的exec()方法相同,接受一个参数(可以说正则表达式、RegExp对象)
- search(): 始终返回第一个匹配的位置,其余与match相同
- replace(): 替换
- split(): 根据传入的分隔符将字符串拆分成数组
- localCompare() 方法:实现所在的地区决定了这个方法如何比较字符串
- HTML方法
单例内置对象
Global
/**
* encodeURI()
* encodeURIComponent()
*
* decodeURI() 只对encordURI()编码的字符进行解码
* decodeURIComponent() 解码所有被encodeURIComponent()编码的字符
*/
let url = 'http:// www.azoux.com/azou domy.js'
console.log(encodeURI(url)); // http://%20www.azoux.com/azou%20domy.js
console.log(encodeURIComponent(url)); // http%3A%2F%2F%20www.azoux.com%2Fazou%20domy.js
/**
* eval()方法:这个方法就是一个完整的ECAMScript解释器,它接受一个参数,即一个要执行的JavaScript字符串
* 当解释器发现eval时,会把eval中的代码插入到该位置
* 通过eval调用的代码,属于调用所处的执行上下文
*/
eval('console.log("azoux");');
// 等价于 console.log("azoux");
/**
* Global 对象属性
* 有个表格,基本都是一些构造函数和特殊值
*/
/**
* window对象
* 浏览器将window对象实现为Global对象的代理
* 另一种获取Global对象的方式
*/
let global = function () {
return this;
}();
console.log(global); // window
Math
/**
* Math对象属性: 具体查表
*/
/**
* min()和 max()方法
* 用于确定一组数值的最大最小值
*/
console.log(Math.min(...[1, 2, 3, 4, 5, 6])); // 1
console.log(Math.max(...[1, 2, 3, 4, 5, 6])); // 6
/**
* 舍入方法
* Math.ceil(): 始终向上舍入为最接近的整数
* Math.floor():始终向下舍入为最接近的整数
* Math.round():四舍五入
* Math.fround():返回数值最接近的单精度(32位)表示
*/
/**
* random()方法:随机返回0~1之间的小数
*/
/**
* 其他方法:查表
*/
Javascript高级程序设计第五章 | ch5 | 阅读笔记的更多相关文章
- javascript高级程序设计第三章的一些笔记
[TOC] 1. 语法 1.1 区分大小写 变量.函数名和操作费都区分大小写. 1.2 标识符 标识符指变量.函数.属性的名字,或者函数的参数.标识符按以下规则组合: 第一个字符必须是一个字母,下划线 ...
- 《JavaScript高级程序设计》——第二章在HTML使用JavaScript
这章讲的是JavaScript在HTML中的使用,也就是<script>元素的属性.书中详细讲了async.defer.src和type四个<script>的属性. 下面是对第 ...
- JavaScript 高级程序设计 第5章引用类型 笔记
第五章 引用类型 一.object类型 1.创建方法: 1.使用new 操作符创建 var person=new object() Person.name=”Nicholasa” Porson.age ...
- 《JavaScript 高级程序设计》第一章:简介
JavaScript 历史 JavaScript的诞生的主要是当时的 netspace 公司谋求为自己的浏览器 Navigator 添加一种脚本语言,以便在本地客户端进行一些行为操作,而这一功能的需求 ...
- JavaScript高级程序设计第20章JSON 笔记 (学习笔记)
第二十章 JSON 1.Json 可以表示三种类型的值: 1.简单值: 表示数值:5 表示字符串:“hello wrold”注表示字符串时必须使用双引号 2.对象: {“name”:“mi”,”ag ...
- JavaScript高级程序设计第14章表单脚本 (学习笔记)
第十四章 表单脚本 1.阻止默认表单提交 1.提交表单数据 1.使用type=submit提交按钮 2.使用submit():方法 注意:当用户点击提交按钮时,会触发submit事件,从而在这里我们有 ...
- 读书时间《JavaScript高级程序设计》五:DOM
DOM(文档对象模型)是针对HTML文档的一个API,描绘了一个层次化的节点树,可以添加.移除.修改页面的某一部分. 一个简单的文档结构 <!DOCTYPE html> <html& ...
- 《JAVASCRIPT高级程序设计》第一章
在使用调制解调器的时代,频繁的表单验证对客户端来说是一个很大的负担,javascript,作为一种专门进行表单验证的客户端脚本语言诞生了.到今天,javascript早已超越了当初设定的角色.Java ...
- 《JavaScript高级程序设计》——第一章JavaScript简介
第一章主要讲了JavaScript的诞生和发展.刚刚接触JavaScript的我,似乎对这些内容并不感兴趣,快速看了一遍就开始去看第二章了. 看完第一章,收获也就是了解到JavaScript由ECMA ...
- javascript高级程序设计第5章,引用类型
object类型: 创建object实列的方式有两种,一种是new()方法,一种是对象字面量表示法: 第一种法方: var obj = new object(); obj.name = 'name' ...
随机推荐
- Dubbo 3.0 前瞻系列 | 2020双11,Dubbo3.0 在考拉的超大规模实践
很多开发者一直以来好奇:阿里自己有没有在用Dubbo,会不会用Dubbo?在刚刚结束的双11,我们了解到阿里云今年提出了"三位一体"的理念,即将"自研技术".& ...
- Nacos2.0的K8s服务发现生态应用及规划
简介:Nacos 是阿里巴巴于 2018 年开源的注册中心及配置中心产品,帮助用户的分布式微服务应用进行服务发现和配置管理功能.随着 Nacos2.0 版本的发布,在性能和扩展性上取得较大突破后,社 ...
- 使用 rocketmq-spring-boot-starter 来配置、发送和消费 RocketMQ 消息
简介: 本文将 rocktmq-spring-boot 的设计实现做一个简单的介绍,读者可以通过本文了解将 RocketMQ Client 端集成为 spring-boot-starter 框架的开发 ...
- 浅谈分布式一致性:Raft 与 SOFAJRaft
简介: SOFAJRaft已开源 作者 | 家纯来源 | 阿里技术公众号 一 分布式共识算法 (Consensus Algorithm) 1 如何理解分布式共识? 多个参与者针对某一件事达成完全一致: ...
- LVGL 日志
一.启动日志 在 lv_conf.h 中将 LV_USE_LOG 设置为 1,如下图所示: 二.日志级别 在文件 lvgl/src/misc/lv_log.h 中定义了日志等级,等级是从小到大,所以 ...
- 记录一个解决固定定位内容不能滚动的方法(vant组件tab必用的css样式)
vant组件下边是循环出来的,在开发中这部分必定是个单独的组件,内容溢出时添加滚动的样式,当然这个需要写在外部引入的自定义的vant组件样式当中 .van-tabs__content{ width: ...
- 学会使用 NumPy:基础、随机、ufunc 和练习测试
NumPy NumPy 是一个用于处理数组的 Python 库.它代表"Numerical Python". 基本 随机 ufunc 通过测验测试学习 检验您对 NumPy 的掌握 ...
- vue3.0 yarn启动项目
linux 系统 在root账号下 yarn install yarn run serve 启动服务 ctrl+c //暂停服务 yarn build 打包服务 在公共目录里添加配置文件 优点:这样就 ...
- ansible(2)--ansible的安装与配置文件管理
目录 1 ansible的安装 1.1 yum安装 1.2 pip安装 2 ansible相关文件 2.1 ansible配置文件 2.2 ansible配置文件的优先级 2.3 ansible的主机 ...
- EasyExcel处理Mysql百万数据的导入导出案例,秒级效率,拿来即用!
一.写在开头 今天终于更新新专栏 <EfficientFarm> 的第二篇博文啦,本文主要来记录一下对于EasyExcel的高效应用,包括对MySQL数据库百万级数据量的导入与导出操作,以 ...