JavaScript 中的单例内置对象:Global 与 Math 的深度解析
JavaScript 中的单例内置对象:Global 与 Math 的深度解析
在 JavaScript 的世界中,单例内置对象是开发者必须了解的核心概念之一。它们是语言规范中预定义的对象,无需显式创建即可直接使用。本文将深入解析 JavaScript 中最重要的两个单例内置对象——Global
和 Math
,并通过实际案例帮助你理解它们的底层原理与应用场景。
一、什么是单例内置对象?
根据 ECMA-262 标准的定义,内置对象是“由 ECMAScript 实现提供、与宿主环境无关,并在程序开始执行时就存在的对象”。而单例意味着这些对象在整个程序运行期间只有一个实例。开发者无需手动创建它们,可以直接使用。
JavaScript 中的单例内置对象包括:
- Global:全局作用域的兜底对象。
- Math:提供数学计算功能的对象。
它们的核心特点是:无需 new
实例化,直接通过对象名调用方法或属性。
二、Global 对象:全局作用域的“幕后管家”
1. Global 的本质
Global 对象是 JavaScript 中最特殊的对象。它负责管理所有不属于任何特定对象的属性和方法。在浏览器环境中,Global 对象通过 window
对象实现(即 window
是 Global 的代理)。
关键点:在全局作用域中定义的变量和函数,实际上是 Global 对象的属性和方法。例如:
let msg = "Hello, World!";
function sayHi() {console.log("Hi!");
}
console.log(window.msg); // 输出 "Hello, World!"
console.log(window.sayHi); // 输出函数定义
2. Global 的常用方法
(1)URL 编码与解码
encodeURI()
和 encodeURIComponent()
用于对 URI 进行编码,确保浏览器能正确解析 URL 中的特殊字符。
const uri = "http://www.example.com/illegal value.js#start";
console.log(encodeURI(uri));
// 输出: "http://www.example.com/illegal%20value.js#start"
console.log(encodeURIComponent(uri));
// 输出: "http%3A%2F%2Fwww.example.com%2Fillegal%20value.js%23start"
encodeURI()
不会编码 URI 的结构字符(如:
、/
、?
)。encodeURIComponent()
会编码所有非标准字符,适合对 URI 的组件(如路径参数)进行编码。
(2)eval():动态执行代码
eval()
是 Global 对象最强大的方法之一,它可以将字符串作为 JavaScript 代码执行。
eval("console.log('Hello from eval!')");
// 等价于直接执行:console.log('Hello from eval!');
警告:
eval()
会带来严重的安全风险(如代码注入攻击),并且可能导致性能问题,因此应尽量避免使用。
(3)this 的默认绑定
当函数没有显式指定 this
时,this
会指向 Global 对象(在浏览器中是 window
)。
function testThis() {console.log(this === window); // true
}
testThis();
三、Math 对象:数学计算的“瑞士军刀”
1. Math 的核心功能
Math
对象提供了丰富的数学运算方法,涵盖了随机数生成、舍入操作、三角函数等场景。它的实现通常基于底层处理器指令,因此性能远超手动实现的算法。
(1)随机数生成
Math.random()
返回一个介于 0(含)和 1(不含)之间的随机数。
// 生成 1-100 的随机整数
const randomInt = Math.floor(Math.random() * 100) + 1;
console.log(randomInt);
(2)舍入操作
console.log(Math.ceil(3.1)); // 向上取整 → 4
console.log(Math.floor(3.9)); // 向下取整 → 3
console.log(Math.round(3.4)); // 四舍五入 → 3
console.log(Math.fround(3.14159)); // 转换为 32 位浮点数 → 3.1415901
(3)最大值与最小值
Math.max()
和 Math.min()
可以快速找出一组数中的最大值和最小值。
const numbers = [5, 2, 9, 1, 7];
console.log(Math.max(...numbers)); // 9
console.log(Math.min(...numbers)); // 1
(4)数学常量
Math
对象还提供了许多数学常量,如:
console.log(Math.PI); // 圆周率 π ≈ 3.14159
console.log(Math.E); // 自然对数的底数 e ≈ 2.71828
四、Global 与 Math 的性能与精度问题
1. 性能优势
- Global 方法:如
parseInt()
和isFinite()
是 JavaScript 引擎内置的优化方法,执行速度远高于手动实现的逻辑。 - Math 方法:由于底层使用了处理器指令(如 SSE 指令集),其计算效率极高。
2. 精度陷阱
- Math 计算:由于 JavaScript 使用 IEEE 754 双精度浮点数格式,某些数学运算可能会出现精度丢失问题。例如:
console.log(0.1 + 0.2 === 0.3); // false
- 解决方案:使用
Math.fround()
或第三方库(如decimal.js
)处理高精度计算。
五、实际应用场景
1. Global 对象的应用
- URL 编码:在构建动态 URL 或处理 API 请求时,
encodeURI()
和encodeURIComponent()
是必不可少的工具。 - 全局变量管理:在浏览器中,
window
对象常用于存储全局状态(如用户登录信息)。
2. Math 对象的应用
- 游戏开发:使用
Math.random()
生成随机事件(如掉落物品、敌人生成)。 - 数据可视化:通过
Math.sin()
、Math.cos()
实现动态图表(如波形图)。 - 算法优化:利用
Math.max()
和Math.min()
简化数组处理逻辑。
六、总结与建议
1. 核心总结
- Global 对象是全局作用域的“兜底者”,所有全局变量和函数都是它的属性。
- Math 对象是数学计算的“加速器”,提供高效且标准化的数学方法。
- 它们都属于单例内置对象,无需实例化即可直接使用。
2. 使用建议
- 避免滥用 Global 变量:过多的全局变量可能导致命名冲突和内存泄漏。
- 谨慎使用 eval():优先考虑更安全的替代方案(如函数构造器)。
- 关注精度问题:在金融计算或科学计算中,使用专门的库处理浮点数。
JavaScript 的单例内置对象是语言设计的基石,理解它们的原理和用法,不仅能提升代码效率,还能帮助开发者规避潜在陷阱。希望本文能为你打开一扇通往 JavaScript 深层世界的大门!
相关文章:
JavaScript 中的单例内置对象:Global 与 Math 的深度解析
JavaScript 中的单例内置对象:Global 与 Math 的深度解析 在 JavaScript 的世界中,单例内置对象是开发者必须了解的核心概念之一。它们是语言规范中预定义的对象,无需显式创建即可直接使用。本文将深入解析 JavaScript 中最重要的两个单例内…...

11 - ArcGIS For JavaScript -- 高程分析
这里写自定义目录标题 描述代码实现结果 描述 高程分析是地理信息系统(GIS)中的核心功能之一,主要涉及对地表高度数据(数字高程模型, DEM)的处理和分析。 ArcGIS For JavaScript4.32版本的发布,提供了Web端的针对高程分析的功能。 代码实现 <!doct…...

通道注意力
一、 什么是注意力 其中注意力机制是一种让模型学会「选择性关注重要信息」的特征提取器,就像人类视觉会自动忽略背景,聚焦于图片中的主体(如猫、汽车)。 transformer中的叫做自注意力机制,他是一种自己学习自己的机制…...

2048游戏的技术实现分析-完全Java和Processing版
目录 简介Processing库基础项目构建指南项目结构核心数据结构游戏核心机制图形界面实现性能优化代码详解设计模式分析测试策略总结与展望简介 2048是一款由Gabriele Cirulli开发的经典益智游戏。本文将深入分析其Java实现版本的技术细节。该实现使用了Processing库来创建图形界…...

全国县域统计年鉴PDF-Excel电子版-2022年
全国县域统计年鉴PDF-Excel电子版-2022年.ziphttps://download.csdn.net/download/2401_84585615/89784662 https://download.csdn.net/download/2401_84585615/89784662 《中国县域统计年鉴》是一部全面反映中国县域社会经济发展状况的资料性年鉴。自2014年起,该年…...
平滑技术(数据处理,持续更新...)
一.介绍 “平滑”是一种用于减少数据中的短期波动、噪声或者异常值的技术,从而更清晰地揭示数据的长期趋势或周期性特征。 平滑的主要作用: 1.减少噪声。数据中常常包含各种随机噪声或误差,这些误差可能会掩盖数据的真实趋势。平滑可以降低…...
App 上线后还能加固吗?iOS 应用的动态安全补强方案实战分享(含 Ipa Guard 等工具组合)
很多开发者以为 App 一旦上线,安全策略也就定型了。但现实是,App 上线只是攻击者的起点——从黑产扫描符号表、静态分析资源文件、注入调试逻辑,到篡改功能模块,这些行为都可能在你“以为很安全”的上线版本里悄然发生。 本篇文章…...

gitlab CI/CD本地部署配置
背景: 代码管理平台切换为公司本地服务器的gitlab server。为了保证commit的代码至少编译ok,也为了以后能拓展test cases,现在先搭建本地gitlab server的CI/CD基本的编译job pipeline。 配置步骤: 先安装gitlab-runner: curl -L "ht…...

AI大模型在测试领域应用案例拆解:AI赋能的软件测试效能跃迁的四大核心引擎(顺丰科技)
导语 5月份QECon深圳大会已经结束,继续更新一下案例拆解,本期是来自顺丰科技。 文末附完整版材料获取方式。 首先来看一下这个案例的核心内容,涵盖了测四用例设计、CI/CD辅助、测试执行、监控预警四大方面,也是算大家比较熟悉的…...

从零搭建uniapp项目
目录 创建uni-app项目 基础架构 安装 uni-ui 组件库 安装sass依赖 easycom配置组件自动导入 配置view等标签高亮声明 配置uni-ui组件类型声明 解决 标签 错误 关于tsconfig.json中提示报错 关于非原生标签错误(看运气) 安装 uview-plus 组件库…...
数据库密码加密
数据库密码加密 添加jar包构建工具类具体使用优缺点 添加jar包 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId> </dependency>构建工具类 public class PasswordUtil …...
GaLore:基于梯度低秩投影的大语言模型高效训练方法详解一
📘 GaLore:基于梯度低秩投影的大语言模型高效训练方法详解 一、论文背景与动机 随着大语言模型(LLM)参数规模的不断增长,例如 GPT-3(175B)、LLaMA(65B)、Qwenÿ…...

OpenCV CUDA模块图像处理------图像融合函数blendLinear()
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 该函数执行 线性融合(加权平均) 两个图像 img1 和 img2,使用对应的权重图 weights1 和 weights2。 融合公式…...
Linux服务器如何安装wps?
1.到wps官网 https://www.wps.cn/product/wpslinux 2.到安装目录上执行命令 sudo dpkg -i wps-office*.deb 3.启动wps 在终端中输入 wps 命令即可启动 WPS...

图片压缩工具 | 图片生成PDF文档
OPEN-IMAGE-TINY,一个基于 Electron VUE3 的图片压缩工具,项目开源地址:https://github.com/0604hx/open-image-tiny ℹ️ 需求描述 上一版本发布后,有用户提出想要将图片转换(或者说生成更为贴切)PDF文档…...
Python的浅拷贝与深拷贝
一、浅拷贝 浅拷贝,指的是重新分配一块内存,创建一个新的对象,但里面的元素是原对象中各个子对象的引用。 浅拷贝有几种方法: 1、 使用数据类型本身的构造器 list1[1,2,3]list2 list(list1) # 使用了数据类型本身的构造器 list…...

VSCode - VSCode 放大与缩小代码
VSCode 放大与缩小代码 1、放大 点击顶部菜单栏【查看】 -> 点击外观 -> 点击【放大】 或者,使用快捷键:Ctrl # 操作方式先按住 Ctrl 键,再按 键2、缩小 点击顶部菜单栏【查看】 -> 点击外观 -> 点击【缩小】 或者&#x…...
消息队列处理模式:流式与批处理的艺术
🌊 消息队列处理模式:流式与批处理的艺术 📌 深入解析现代分布式系统中的数据处理范式 一、流式处理:实时数据的"活水" 在大数据时代,流式处理已成为实时分析的核心技术。它将数据视为无限的流,…...

11-Oracle 23ai Vector Embbeding和ONNX
Embedding (模型嵌入)是 AI 领域的一个核心概念 一、Embedding(嵌入)的含义 Embedding 是一种将 非结构化数据(如文本、图像、音频、视频)转换为 数值向量的技术。 其核心是通过 嵌入模型(…...
Build a Large Language Model (From Scratch) 序章
关于本书 《从零构建大型语言模型》旨在帮助读者全面理解并从头创建类似GPT的大型语言模型(LLMs)。 全书首先聚焦于文本数据处理的基础知识和注意力机制的编码,随后指导读者逐步实现一个完整的GPT模型。书中还涵盖了预训练机制以及针对文本…...
【HarmonyOS 5】教育开发实践详解以及详细代码案例
以下是基于 HarmonyOS 5 的教育应用开发实践详解及核心代码案例,结合分布式能力与教育场景需求设计: 一、教育应用核心开发技术 ArkTS声明式UI 使用 State 管理学习进度状态,LocalStorageProp 实现跨页面数据同步(如课程…...
NoSQL 之Redis哨兵
目录 一、Redis 哨兵模式概述 (一)背景与核心目标 (二)基本架构组成 (三)核心功能 二、哨兵模式实现原理 (一)配置关键参数 (二)哨兵节点的定时任务 …...
【nano与Vim】常用命令
使用nano编辑器 保存文件 : 按下CtrlO组合键,然后按Enter键确认文件名。 退出编辑器 : 按下CtrlX组合键。 使用vi或vim编辑器 保存文件 : 按Esc键退出插入模式,然后输入:w并按Enter键保存文件。 退出编辑器 …...

OpenCV 图像色彩空间转换与抠图
一、知识点: 1、色彩空间转换函数 (1)、void cvtColor( InputArray src, OutputArray dst, int code, int dstCn 0, AlgorithmHint hint cv::ALGO_HINT_DEFAULT ); (2)、将图像从一种颜色空间转换为另一种。 (3)、参数说明: src: 输入图像,即要进行颜…...

Amazing晶焱科技:电子系统产品在多次静电放电测试后的退化案例
在我们的电子设计世界里,ESD(静电放电)问题总是让人头疼。尤其是当客户面临系统失效的困境时,寻找一个能够彻底解决问题的方案就变得格外重要。这一次,我们要谈的是一个经典案例:电子系统产品在多次静电放电…...
Go 中的 Map 与字符处理指南
Go 中的 Map 与字符处理指南 在 Go 中,map 可以存储字符,但需要理解字符在 Go 中的表示方式。在 Go 语言中,"字符" 实际上有两种表示方法:byte(ASCII 字符)和 rune(Unicode 字符&…...
互联网大厂Java求职面试:云原生架构下的微服务网关与可观测性设计
互联网大厂Java求职面试:云原生架构下的微服务网关与可观测性设计 郑薪苦怀着忐忑的心情走进了会议室,对面坐着的是某大厂的技术总监张总,一位在云原生领域有着深厚积累的专家。 第一轮面试:微服务网关的设计挑战 张总…...
C++中const关键字详解:不同情况下的使用方式
在 C 中,const 关键字用于指定一个对象或变量是常量,意味着它的值在初始化之后不能被修改。下面详细介绍 const 修饰变量、指针、类对象和类中成员函数的区别以及注意事项。 修饰变量 详细介绍 当 const 修饰变量时,该变量成为常量&#x…...
Java 2D 图形类总结与分类
一、基本形状类 这些类用于绘制简单的标准几何形状。 1. 圆形 / 椭圆类 Ellipse2D:椭圆基类,支持浮点精度。 子类: Ellipse2D.Double:双精度浮点坐标。Ellipse2D.Float:单精度浮点坐标。 参数:x, y, wid…...

C# 快速检测 PDF 是否加密,并验证正确密码
引言:为什么需要检测PDF加密状态? 在批量文档处理系统(如 OCR 文字识别、内容提取、格式转换)中,加密 PDF 无法直接操作。检测加密状态可提前筛选文件,避免流程因密码验证失败而中断。 本文使用 Free Spire…...