✏️
ougege
  • README
  • Docs
    • index
    • Articles
      • AI
        • 体验Chrome AI
        • 体验Cloudflare Workers AI
        • 体验deepseek
      • CSS
        • CSS优化-PurgeCSS
        • 实用效果
        • 开发常用样式
      • Deepin
        • deepin20安装mysql
        • deepin使用tensorflow入门机器学习
        • deepin安装cuda和cuDNN
        • deepin安装lamp
        • deepin安装nvidia驱动
        • deepin安装oh my Zsh
        • deepin安装p7zip
        • deepin换源
        • 安装deepin系统后要做的事
      • Docker
        • CI/CD搭建配置
        • deepin搭建docker环境
        • docker安装和使用gitlab
        • docker搭建nginx+php环境
      • Essay
        • IOS申请邓白氏编码
        • Markdown-Mermaid
        • Markdown Use
        • webview白屏的问题查找和修复
        • 前端开发对接问题和解决办法汇总
        • 国务院机构改革方案
        • 国家级智库
        • 实用网站推荐
        • 常用Markdown数学公式语法
        • 强烈推荐前端要安装的vscode扩展
        • 新建销售计划-页面卡死问题分析
        • 海淘入坑手册
        • 竞品研究
        • 足球知识速成
      • Git
        • GitBook安装和常用命令
        • GitKraken免费版本
        • Git安装和配置
        • Git异常处理
        • Git Worktree使用
        • 前端工程化相关的实用git命令
      • JS
        • ESM模块导出方式对比
        • Emoji多端统一处理
        • JS发布订阅模式
        • JS性能优化
        • JS标准内置对象
        • JS链式调用原理
        • Promise介绍和使用
        • Range的使用
        • Vue+Oauth登录实现
        • Vue实现富文本插入Emoji
        • chrome扩展入门
        • es5新特性
        • es6常用特性
        • es常用片段
        • uniapp使用eslint校验代码
        • 与移动端通信
        • 优秀js库moment
        • 使用vue-socketio
        • 实现一个中间件
        • 小程序webview调试
        • 常用snippets
        • 常用正则
        • 常用的设计模式
        • 微信jssdk封装使用
        • 浏览器宏任务和微任务
        • 浏览器的5种Observer
        • 深入理解赋值、浅拷贝、深拷贝
        • 解析vue指令clickoutside源码
        • 键盘事件与KeyBoardWrapper交互
        • 高德地图常用方法封装
        • 高阶函数片段
      • Network
        • 使用Lighthouse分析前端性能
        • 前后端启用https
        • 宝塔nginx安装ngx_brotli
        • 比较gz与br加载速度
        • 浏览器https提示不安全
        • 浏览器提示HSTS
        • 简单使用tcpdump
        • 静态资源gzip优化
      • Node
        • CommonJS模块导出方式对比
        • Taro command not found 多平台解决方案
        • koa使用和API实现
        • node安装报错Unexpected-token
        • 使用nvm和nrm
        • 使用uniapp给小程序添加云函数
        • 使用verdaccio搭建本地npm仓库
        • 使用vue-cli搭建vue项目
        • 安装Node.js和npm配置
        • 编译成cjs和mjs的思路解析
        • 让你的npmPackage同时支持cjs和mjs
        • 通过GithubAction将内容部署到vps
      • Python
        • Python源管理
        • Python版本管理
        • mitmproxy抓包
        • 微信公众平台开发爬坑经历
      • Shell
        • Ubuntu安装deepin桌面环境
        • Ubuntu安装flatpak软件
        • Ubuntu安装wireshark
        • Ubuntu常见问题汇总
        • dell G3装系统无法识别第二块硬盘
        • linux下virtualbox用gho还原系统
        • mysql常用命令
        • navicat连接一键集成环境的mysql
        • nginx常用命令
        • pm2常用命令
        • virtualbox虚拟机和宿主机互相复制粘贴
        • vps内资源通过mega快传到本地
        • vps报错temporary failure in name resolution
        • vscode修改文件监控数
        • windows+linux双系统引导修复
        • zsh常用插件和命令
        • 一键搭建ChatGPT web版
        • 使用V2ray,CloudFlare Warp解锁GPT
        • 使用vscode进行java开发
        • 利用zx和SSHKey发布代码到服务器
        • 反爬虫一些方案总结和尝试
        • 安装1Panel
        • 安装Bt面板
        • 安装Ubuntu22.04后要做的事
        • 无显示器linux设置默认分辨率
        • 特别实用的shell命令
        • 解决linux安装xmind缺少依赖报错
      • Standards
        • CSS格式化之stylelint
        • CSS规范
        • HTML规范
        • JS规范
        • commit规范
        • 使用husky+commitlint规范代码提交
        • 使用semantic-release自动管理版本号
        • 命名规范
        • 图片规范
        • 版本编号规范
      • Wall
        • 科学上网-Cloudflare-Pages
        • 科学上网-Cloudflare-Warp
        • 科学上网-Geph
        • 科学上网-RackNerd
        • 科学上网-Slicehosting
        • 科学上网-Surfshark
        • 科学上网-Tor
        • 科学上网-XX-NET
        • 科学上网-heroku
        • 科学上网-shadowsock
        • 科学上网-v2ray使用
        • 科学上网-v2ray搭建
        • 科学上网-浏览器代理
        • 科学上网-让终端走代理
      • Windows
        • SourceTree破解免登录(windows版)
        • git bash交互提示符不工作
        • nexus 7 2013 wifi 刷机
        • tree命令生成文件目录
        • 利用charles抓包app
        • 安装Openssl
        • 安装msi文件报错2503和2502
        • 神器vimium使用说明
        • 自用host
        • 解决win10扩展出来的屏幕模糊
        • 解决安装Adobe Air时发生错误
    • Snippets
      • zsh
        • docker
        • extract
        • git-commit
        • git
        • mysql-macports
        • npm
        • nvm
        • pip
        • pm2
        • systemd
        • ubuntu
        • vscode
Powered by GitBook
On this page
  • 值属性
  • 函数属性
  • 基本对象

Was this helpful?

  1. Docs
  2. Articles
  3. JS

JS标准内置对象

PreviousJS性能优化NextJS链式调用原理

Last updated 10 months ago

Was this helpful?

值属性

  • Infinity :无穷大,初始值是 Number.POSITIVE_INFINITY

  • NaN : 不是一个数字,初始值是 NaN ,不等于自己

  • undefined : 未被赋值

  • null 字面量: 对象值未设置,也可作为尚未创建的对象

  typeof null        // "object" (因为一些以前的原因而不是'null')
  typeof undefined   // "undefined"
  null === undefined // false
  null  == undefined // true
  null === null // true
  null == null // true
  !null //true
  isNaN(1 + null) // false
  isNaN(1 + undefined) // true
  • globalThis :

函数属性

  • eval() : 会将传入的字符串当做 JS 代码执行

console.log(eval('2 + 2'));
// expected output: 4

console.log(eval(new String('2 + 2')));
// expected output: 2 + 2

console.log(eval('2 + 2') === eval('4'));
// expected output: true

console.log(eval('2 + 2') === eval(new String('2 + 2')));
// expected output: false
  • isFinite() : 判断传入值是否有限数值(参数是 NaN,正无穷大或负无穷大,返回 false ,其他返回 true)

  • isNaN() : 判断值是否是 NaN ,0除以0返回 NaN

isNaN(NaN);       // true
isNaN(undefined); // true
isNaN({});        // true
isNaN(true);      // false
isNaN(null);      // false
isNaN(37);        // false
isNaN("");        // false: 空字符串被转换成0
  • parseFloat(value): 解析一个字符串并返回一个浮点数

  • parseInt(string, radix) : 参数(字符串,进制)

  • decodeURI(encodeURI) : 解析编码过的 URI

  • decodeURIComponent(encodeURI) : 解析编码过的部分 URI

  • encodeURI(URI) :将提供的字符串编码为统一的资源标识符

  • encodeURIComponent(str) : 使用一到四个转义序列来表示字符串中的每个字符的 UTF-8 编码

  • escape() : 已废弃

  • unescape() : 已废弃

基本对象

  • Object

    1. Object.assign(target, source) : 将所有可枚举属性的值从一个或多个源对象复制到目标对象

      // 复制一个对象
      const obj = {a: 1}
      const copy = Object.assign({}, obj)
      console.log(copy)
      // 深拷贝问题: 源对象的属性值是一个对象的引用,那么它也只指向那个引用
      let obj1 = { a: 0 , b: { c: 0}}; 
      let obj2 = Object.assign({}, obj1); 
      console.log(JSON.stringify(obj2)); // { a: 0, b: { c: 0}} 
    
      obj2.a = 2; 
      console.log(JSON.stringify(obj1)); // { a: 1, b: { c: 0}} 
      console.log(JSON.stringify(obj2)); // { a: 2, b: { c: 0}}
    
      obj2.b.c = 3; 
      console.log(JSON.stringify(obj1)); // { a: 1, b: { c: 3}} 
      console.log(JSON.stringify(obj2)); // { a: 2, b: { c: 3}} 
    
      // 深克隆
      obj1 = {a:0, b: {c: 0}}
      let obj3 = JSON.parse(JSON.stringify(obj1))
      obj1.a = 4;
      obj1.b.c = 4;
      console.log(JSON.stringify(obj3)); // {a: 0, b: {c: 0}}
    
      // 合并对象
      const o1 = {a: 1}
      const o2 = {b: 2}
      const o3 = {c: 3}
      const obj = Object.assign(o1, o2, o3)
      console.log(obj) // {a: 1, b: 2, c: 3}
      console.log(o1) // {a: 1, b: 2, c: 3} 目标对象自身也会改变
    
      // 合并具有相同属性的对象
      const o1 = {a: 1, b: 1, c: 1}
      const o2 = {b: 2, c: 2}
      const 03 = {c: 3}
      const obj = Object.assign({}, o1, o2, o3)
      console.log(obj)  // {a: 1, b: 2, c: 3}
      // 继承属性和不可枚举属性是不能拷贝的
      const obj = Object.create({foo: 1}, { // foo 是个继承属性
        bar: {
          value: 2 // bar是个不可枚举属性
        },
        baz: {
          value: 3,
          enumerable: true // baz是个自身可枚举属性
        }
      })
      const copy = Object.assign({}, obj)
      console.log(copy) // {baz: 3}
    1. Object.create() : 一个新对象,带着指定的原型对象和属性

      const person = {
        isHuman: false,
        printIntroduction: function () {
          console.log(`My name is ${this.name}. Am I human? ${this.isHuman}`);
        }
      };
    
      const me = Object.create(person);
    
      me.name = "Matthew"; // "name" is a property set on "me", but not on "person"
      me.isHuman = true; // inherited properties can be overwritten
    
      me.printIntroduction();
      // expected output: "My name is Matthew. Am I human? true"
    1. Object.defineProperty(obj, prop, descriptor) : 被传递给函数的对象 configurable:当值为 true 时,该属性描述符才能够被改变,同时该属性也能从对应的对象上被删除.默认为 false enumerable:当值为 true 时,该属性才能够出现在对象的枚举属性中,默认为 false value: 变量值,默认 undefined writable: 当值为 true 时, value 才能被赋值运算符改变,默认为 false get: 给属性提供 getter 的方法,如果没有 getter 则为 undefined ,默认 undefined set: 给属性提供 setter 的方法,如果没有 setter 则为 undefined ,属性值修改时,触发执行该方法,默认 undefined

uneval() :

标准内置对象
实验功能
非标准