js - 递归函数和对象数据类型

简介: js - 递归函数和对象数据类型

递归函数

自己调用自己的过程。

  1. 本质:循环环
  1. 三要素:从哪里开始,到哪里结束、步长

建议在循环嵌套不确定层数时,使用递归函数。

// 下面这个代码就是一个最简单的递归函函数

// 在函数内部调用了自己,函数一执行,就调用自己一次,在调用再执行,循环往复,没有止尽

function fn() {

 fn()

}

fn()

对象数据类型

创建对象数据类型

  1. 如何创建对象?
  • 字面量方式: {key: value,key: value}
  • 构造函数方式: new 构造函数名()
  1. 构造函数的语句:

function 构造函数名-大驼峰命名([参数]){

   //属性

   this.属性名 = 属性值;

   //方法

   this.方法名 = function(){

       //功能

   }

}

对象数据类型的操作(增删改查),两种语法

  1. 对象.属性 对象.方法()
  2. 对象['属性'] 对象'方法'

for in 循环遍历对象

for(循环变量 in 对象){

   语句组;

}

//注:循环变量不能赋值,循环变量不能赋值,循环变量不能赋值!

数组数据类型

  1. 什么是数组? 存储一组或一系列数据的容器。

创建数组数据类型 声明数组的方式

  1. 字面量创建方式:: [] 中括号代表的是数组 <!-- 里面存储的元素,为数组元素 -->
  1. 构造函数方式: new Array() 内置对象表示数组 <!-- 1. 如果里面只有一个正整数时,表示数组长度,开辟了多少个空间. 2.如果构造函数中,只有一个负数时,直接报错3.如果构造函数中,只有一个小数时,直接报错4.如果构造函数中有一个非数字类型的数据,则表示数组元素,存储的数据 5.如果构造函数中,有多个数据,则表示数组元素,储存的数据 -->

数组的length属性

  1. length : 表示数组的长度 该属性可读可写 清空数组使用时较多 删掉长度是从尾端进行删除

检测是否为数组

  1. instanceof 运算符 他可以用来检测是否为数组
  2. Array.isArray(参数) 用来检测是否为数组.

数组的索引概念

下标:可以唯一标识一个数组空间的索引号。 (最小下标:0)(最大下标:长度 - 1)

for循环遍历数组

  1. 数组名[下标]
  2. 遍历数组:一个一个处理(循环)

不同数据类型的存储

堆和栈空间存储数据

栈空间: 一个栈空间里面只能存储一个数据 <!-- 基本类型的数据只能一个值,所以存储在栈空间中,属于值传递 -->


1.基本数据类型的数据属于值传递 <!-- 复合数据类型,代表有多个值,多个值放堆空间中,而堆空间的地址存储在栈空间里,所以属于引用传递(地址传递) -->


2.复合数据类型的数据属于引用传递(地址传递)


相关文章
|
4天前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
4天前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
14 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
3天前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
4天前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。
|
17天前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
19天前
|
存储 JavaScript 前端开发
JS函数提升 变量提升
【10月更文挑战第6天】函数提升和变量提升是 JavaScript 语言的重要特性,但它们也可能带来一些困惑和潜在的问题。通过深入理解和掌握它们的原理和表现,开发者可以更好地编写和维护 JavaScript 代码,避免因不了解这些机制而导致的错误和不一致。同时,不断提高对执行上下文等相关概念的认识,将有助于提升对 JavaScript 语言的整体理解和运用能力。
|
22天前
|
存储 JavaScript 前端开发
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
JavaScript 数据类型分为基本数据类型和引用数据类型。基本数据类型(如 string、number 等)具有不可变性,按值访问,存储在栈内存中。引用数据类型(如 Object、Array 等)存储在堆内存中,按引用访问,值是可变的。本文深入探讨了这两种数据类型的特性、存储方式、以及检测数据类型的两种常用方法——typeof 和 instanceof,帮助开发者更好地理解 JavaScript 内存模型和类型检测机制。
48 0
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
|
26天前
|
缓存 JavaScript 前端开发
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
29 1
|
22天前
|
存储 JavaScript 前端开发
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
16 0
|
22天前
|
JavaScript 前端开发 大数据
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
12 0