数组与函数

js
2024-11-04 10:16

数组

「1. 数组的概念」 一组数据的集合,其中的每个数据被称作元素,在数组中可以存放任意类型的元素。数组是一种将一组数据存储在单个变量名下的优雅方式。

「2. 创建数组」

  • 利用new关键字创建数组;

    var 数组名 = new Array([n]);//[]代表可选 若写n,则代表数组的长度
    var arr = new Array();//创建了一个名为 arr 的空数组
  • 利用数组字面量创建数组

    // 1. 使用数组字面量方式创建空的数组
    var 数组名 = [];//若写n,则代表数组的长度
    
    //2. 使用数组字面量方式创建带初始值的数组
    //3. 声明数组并赋值称为数组的初始化
    var arr =['1','2','3','4'];
    var arr2 = ['fan',true,17.5];//数组中可以存放任意类型的数据

「3. 访问数组元素」

索引(下标):用来访问数组元素的序号。索引从 0 开始图片

  // 定义数组
  var arrStus = [1,2,3];
  // 获取数组中的第2个元素 
  alert(arrStus[1]); 
  // 如果访问数组时没有和索引值对应的元素(数组越界),
  // 返回值为undefined

「4. 遍历数组」

把数组中的元素从头到尾都访问一次。

 // 数组的长度,默认情况下等于元素的个数
 // 当我们数组里面的元素发生了变化,length属性跟着一起变
 // 如果设置的length属性值大于数组的元素个数,则会在数组末尾出现空白元素;
 // 如果设置的length属性值小于数组的元素个数,则会把超过该值的数组元素删除
  var arr = ["red", "blue", "green"];
  for (var i = 0; i < arr.length; i++) {
    console.log(arr[i]);
  }
  
  arr.length = 2;
  console.log(arr);// red blue

「5. 数组中新增元素」

数组中可以通过以下方式在数组的末尾插入新元素;

  // 1. 数组[数组.length] = 新数据;
  arr = [] //arr.length = 0;
  for (var i = 0; i < 10; i++) {
    arr[arr.length] = '0';
  }
  console.log(arr);

「6. 案例」

  // 1. 筛选数组 大于10的元素选出来放到新数组中
  var arr = [2, 0, 6, 1, 77, 0, 52, 0, 25, 7];
  var newArr = [];
  var j = 0;
  for (var i = 0;i < arr.length; i++){
    if (arr[i] >= 10) {
      newArr[j] = arr[i];
      j++;
    }
  }
  console.log(newArr);
  //第二种方法 利用数组长度的可变性
  for (var i = 0;i < arr.length; i++){
    if (arr[i] >= 10) {
      newArr[j] = arr[i];
      j++;
    }
  }
  // 2. 翻转数组 
  //  把旧数组索引号第4个取过来(arr.length - 1),给新数组索引号第0个元素 (newArr.length)
  //  我们采取 递减的方式  i--
  var arr = ['red', 'green', 'blue', 'pink', 'purple'];
  var newArr = [];
  for(var i = arr.length - 1; i >= 0;i--) {
    newArr[newArr.length] = arr[i]
  }
  console.log(newArr);
  // 3. 数组转换为字符串 用"|" 或其他符号分割
  // 需要一个新变量用于存放转换完的字符串str
  //遍历取出数据加到str后面然后加上分隔符
  var arr = ['red', 'green', 'blue', 'pink', 'purple'];
  var str = '';
  for(var i = 0; i < arr.length; i++) {
    str += arr[i] + '|';
  }
  console.log(str);
  // 4. 数组转换为字符串 用"|" 或其他符号分割
  // 需要一个新变量用于存放转换完的字符串str
  //遍历取出数据加到str后面然后加上分隔符
  var arr = ['red', 'green', 'blue', 'pink', 'purple'];
  var str = '';
  for(var i = 0; i < arr.length; i++) {
    str += arr[i] + '|';
  }
  console.log(str);

冒泡排序图片

  function sort(arr) {
    for(var i = 0; i < arr.length - 1; i++) {
      for(var j = 0; j < arr.length - 1 - i; j++) {
        if (arr[j] > arr[j+1]){
          var temp = arr[j];
          arr[j] = arr[j+1];
          arr[j+1] = temp;
        }
      }
    }
    return arr;
  }
  var arr1 = sort([1,4,2,9]); 
  console.log(arr1);//1 2 4 9

函数

「1. 函数的概念」

封装了一段可被重复调用执行的代码块,通过函数可以实现大量代码的重复使用。函数是一种数据类型。

「2. 函数的使用」

  • 声明函数

  1. 通过function关键字定义函数 -- 命名函数
  function 函数名() {
    //函数体代码
  }
  // 1.1 function 是声明函数的关键字,必须小写
  // 1.2 函数名 命名为动词形式 例: getSum
  
   2. 通过函数表达式定义函数 ---匿名函数
  var fn = function() {};
  // 2.1 fn是变量名,不是函数名
  // 2.2 fn是变量,只不过变量存储的是函数
  // 2.3 函数表达式创建的函数可以通过 变量名(); 来调用
  // 2.4 函数表达式也可以定义形参和调用传入实参。
  匿名函数使用的第2种方式--匿名函数自调用
  (function(){
    alert(123);
  })();
  • 调用函数

  函数名();// 函数声明后调用才会执行函数体代码
  • 函数的封装

    • 函数的封装是把一个或者多个功能通过函数的方式封装起来,对外只提供一个简单的函数接口。

  /*
    例用封装函数计算1-100累加和
  */
  function getSum() {
  var sumNum = 0; // 准备一个变量,保存累加和
  for (var i = 1; i <= 100; i++) {
    sumNum += i; // 把每个数值 都累加 到变量中
  }
    alert(sumNum);
  }
  // 调用函数
  getSum();

「3. 函数的参数」

  • 形参:函数定义时候,传递的参数(实参值传递给形参,不用声明的变量)

  • 实参:函数调用时候,传递的参数

  //带参数的函数声明
  function 函数名(形参1,形参2,形参3...) {
    //函数体
  }
  // 带参数的函数调用
  函数名(实参1,实参2,实参3...);
  • 「函数形参和实参数量不匹配时」

参数个数

说明

实参个数等于形参个数

输出正确结果

实参个数多于形参个数

只取到形参的个数

实参个数小于形参

多的形参定义为undefined,结果为NaN

      function getSum(a, b, c) {
        return a + b + c;
      }
      // js中形参的默认值是undefined。
      // 调用函数
      var n = getSum(1, 2);// n = NaN
      var n = getSum(1, 2, 3, 4); //1 + 2 +3 = 6

「4. 函数的返回值」

返回值:函数调用整体代表的数据;函数执行完成后可以通过return语句将指定数据返回 。

  // 声明函数
  function 函数名() {
    ...
    return 需要返回的值;
    // 1. 函数遇到return会停止执行,并返回指定的值
    // 1. 如果函数没有return 返回的值是undefined
  }
  // 调用函数
  函数名(); //此时调用函数就可以得到函数体内return的值
break,continue,return的区别
  • break: 结束当前的循环体 (如for、while)

  • continue: 跳出本次循环,继续执行下次循环

  • return: 不仅可以退出(函数体内)循环,还能够返回return语句中的值,同时还可以结束当前的函数体内的代码

//避免踩坑 return只能结束函数体内的代码
  function breakDown() {
    for (var i = 0; i < 10; i++) {
      if (i == 5) {
        return 1;
      }
    console.log(i);
    }
  }
  breakDown();
  
  //避免踩坑2 函数如果有return 则返回的是 return 后面的值;
  // return d,a,b; 返回的是b的值
  //如果函数没有 return语句,则返回undefined

「5. arguments的使用」

当不确定有多少个参数传递的时候,可以用 arguments 来获取。JS中,arguments实际上它是当前函数的一个内置对象。所有函数都内置了一个 arguments 对象,arguments 对象中存储了传递的所有实参。arguments展示形式是一个伪数组,因此可以进行遍历。

  • 伪数组具有以下特点:

    • 具有length属性

    • 按索引方式存储数据

    • 不具有数组的push,pop等方法

  function fn() {
    //arguments 里面存储了所有传递过来的实参
    console.log(arguments);// [1,2,3...]
    console.log(arguments[1]); // 2
    console.log(arguments.length); // 3
    
    //我们可以按照数组的方式 遍历argument  
  }
  fn(1, 2, 3);
 // 用伪数组 实现求最大值
 function getMax() {
    var max = arguments[0];
    for (var i = 1; i < arguments.length; i++) {
      if (arguments[i] > arguments[0]) {
        max = arguments[i];
      }
    }
    return max;
  }
  var result = getMax(1,3,77,5,85)
  colsole.log(result);
相关文章
热点文章
精彩视频
Tags

站点地图 在线访客: 今日访问量: 昨日访问量: 总访问量: