基本引用类型

Date

  1. 在不给定时间的情况下创建Date实例,创建的对象将保存当前的日期和时间。
  2. 要基于其他时间创建Date对象,必须传入其毫秒时表示
    1. Date.parse()

      1. 月/日/年(5/21/2022)
      2. 月名 日, 年(May 21, 2022)
      3. 周几 月名 日 年 时:分:秒 时区(Tue May 23 2022 00:00:00 GMT-0700)
      4. YYYY-MM-DDTHH:mm:ss.sssZ(2019-05-23T00:00:00只适用于兼容ES5的实现
    2. Date.UTC(年,月,日,时,分,秒):返回日期的毫秒表示

继承的方法

日期格式化方法

日期/时间组件方法

RegExp

原始值包装类型

Boolean

  1. 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

  1. 重写了valueOF() toLocalString() toString()
  2. toFixed() 0~20个小数位
  3. 科学计数法:toExponential()
  4. 返回最合理的输出结果:toPrecision()
  5. isInteger()是否为整数

String

常用方法:

  1. normalize()方法
  2. 字符串操作方法
    1. slice()
    2. substr()
    3. substring()
    4. 第一个参数表示字符串开始位置,第二个参数表示结束位置
    5. 对于substr()而言,第二个参数表示截取的子字符数量
  3. 字符串位置方法
    1. indexOf(str, idx)
    2. lastIndexOf(str, idx)
    3. 在字符串中搜索传入的字符串,并返回位置,没找到则返回-1
    4. indexOf从头开始查找
    5. lastIndexOf从末尾开始
    6. 第二个参数的意思是从指定位置开始查找
  4. 字符串包含方法
    1. startsWith(str):是否以str开头
    2. endWith(str):是否以str结尾
    3. includes(str):是否包含str
    4. 搜索传入的字符串,并返回一个bool值
  5. trim()方法:创建字符串的副本,删除前后所有的空格,再返回结果
  6. repeat(times)方法:返回将字符串拼接times次之后的结果
  7. padStart(len, str)和padEnd(len, str)方法
    1. 将字符串用指定str拼接成长度为len的字符串
    2. padStart是在开头填充
    3. padEnd是在结尾填充
  8. 字符串迭代器与解构
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']
  1. 字符串大小写转换

    1. toLowerCase()
    2. toLocaleLowerCase()
    3. toUpperCase()
    4. toLocaleUpperCase()
    5. local: 针对特对地区实现,如果不知道代码涉及什么语言,最后使用local
  2. 字符串模板方法
    1. match(): 本质上和RegExp对象的exec()方法相同,接受一个参数(可以说正则表达式、RegExp对象)
    2. search(): 始终返回第一个匹配的位置,其余与match相同
    3. replace(): 替换
    4. split(): 根据传入的分隔符将字符串拆分成数组
  3. localCompare() 方法:实现所在的地区决定了这个方法如何比较字符串
  4. 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 | 阅读笔记的更多相关文章

  1. javascript高级程序设计第三章的一些笔记

    [TOC] 1. 语法 1.1 区分大小写 变量.函数名和操作费都区分大小写. 1.2 标识符 标识符指变量.函数.属性的名字,或者函数的参数.标识符按以下规则组合: 第一个字符必须是一个字母,下划线 ...

  2. 《JavaScript高级程序设计》——第二章在HTML使用JavaScript

    这章讲的是JavaScript在HTML中的使用,也就是<script>元素的属性.书中详细讲了async.defer.src和type四个<script>的属性. 下面是对第 ...

  3. JavaScript 高级程序设计 第5章引用类型 笔记

    第五章 引用类型 一.object类型 1.创建方法: 1.使用new 操作符创建 var person=new object() Person.name=”Nicholasa” Porson.age ...

  4. 《JavaScript 高级程序设计》第一章:简介

    JavaScript 历史 JavaScript的诞生的主要是当时的 netspace 公司谋求为自己的浏览器 Navigator 添加一种脚本语言,以便在本地客户端进行一些行为操作,而这一功能的需求 ...

  5. JavaScript高级程序设计第20章JSON 笔记 (学习笔记)

    第二十章 JSON 1.Json 可以表示三种类型的值: 1.简单值: 表示数值:5  表示字符串:“hello wrold”注表示字符串时必须使用双引号 2.对象: {“name”:“mi”,”ag ...

  6. JavaScript高级程序设计第14章表单脚本 (学习笔记)

    第十四章 表单脚本 1.阻止默认表单提交 1.提交表单数据 1.使用type=submit提交按钮 2.使用submit():方法 注意:当用户点击提交按钮时,会触发submit事件,从而在这里我们有 ...

  7. 读书时间《JavaScript高级程序设计》五:DOM

    DOM(文档对象模型)是针对HTML文档的一个API,描绘了一个层次化的节点树,可以添加.移除.修改页面的某一部分. 一个简单的文档结构 <!DOCTYPE html> <html& ...

  8. 《JAVASCRIPT高级程序设计》第一章

    在使用调制解调器的时代,频繁的表单验证对客户端来说是一个很大的负担,javascript,作为一种专门进行表单验证的客户端脚本语言诞生了.到今天,javascript早已超越了当初设定的角色.Java ...

  9. 《JavaScript高级程序设计》——第一章JavaScript简介

    第一章主要讲了JavaScript的诞生和发展.刚刚接触JavaScript的我,似乎对这些内容并不感兴趣,快速看了一遍就开始去看第二章了. 看完第一章,收获也就是了解到JavaScript由ECMA ...

  10. javascript高级程序设计第5章,引用类型

    object类型: 创建object实列的方式有两种,一种是new()方法,一种是对象字面量表示法: 第一种法方:  var obj = new object(); obj.name = 'name' ...

随机推荐

  1. Java Agent 踩坑之 appendToSystemClassLoaderSearch 问题

    简介: 从 Java Agent 报错开始,到 JVM 原理,到 glibc 线程安全,再到 pthread tls,逐步探究 Java Agent 诡异报错. 作者:鲁严波   从 Java Age ...

  2. 「直播回顾」Mars应用与最佳实践

    简介: 本文首先对Mars的概念.功能.优势进行了介绍,随后,对Mars几个典型的应用场景进行介绍,并通过两个Demo展示了在使用Mars后数据科学性能的提升,最后总结了Mars的最佳实践,让使用Ma ...

  3. 可观测告警运维系统调研——SLS告警与多款方案对比

    简介: 本文介绍对比多款告警监控运维平台方案,覆盖阿里云SLS.Azure.AWS.自建系统(ELK.Prometheus.TICK)等方案. 前言 本篇是SLS新版告警系列宣传与培训的第三篇,后续我 ...

  4. [FAQ] golang-migrate/migrate error: default addr for network '127.0.0.1:3306' unknown

    按照项目github文档上所示,在使用 mysql 时你可能会这样写: $ migrate -path db/migrations -database mysql://root:123456@127. ...

  5. 2024 年最值得推荐的 7 个 Vue3 组件库

    你好,我是 Kagol. Vue 是一款易学易用,性能出色,适用场景丰富的渐进式 JavaScript 框架,深受广大开发者的喜爱,Vue3 更是推出了 Composition API,让逻辑复用更友 ...

  6. Unsortbin attack原理及分析

    Unsortbin attack原理 ️条件:首先要实现Unsortbin attack前提是可以控制Unsortbin attack chunk的bk指针 ️目的:我们可以实现修改任意地址为一个比较 ...

  7. 有意思!一个关于 Spring 历史的在线小游戏

    发现 Spring One 的官网上有个好玩的彩蛋,分享给大家! 进到Spring One的官网,可以看到右下角有个类似马里奥游戏中的金币图标. 点击该金币之后,会打开一个新的页面,进入下面这样一个名 ...

  8. 纯css高斯背景模糊(毛玻璃,伪元素,完整实例)

    先上效果图: 写博客不管是做笔记还是干啥,直接上源码不行么,还不放效果图,拆分成几段谁慢慢看,慢慢理解去 自己动手,丰衣足食,上代码: <!DOCTYPE HTML> <html l ...

  9. vue-axios设置公共的请求ip

    1.安装axios,网上找方法 2.src->network->request.js并复制: import axios from 'axios' export function reque ...

  10. 火山引擎A/B测试平台的实验管理重构与DDD实践

    本次分享的主题是火山引擎数智平台VeDI旗下的A/B测试平台 DataTester 实验管理架构升级与DDD实践.这里说明的一点是,代码的第一目标肯定是满足产品需求,能够满足产品需求的代码都是好代码. ...