zoukankan      html  css  js  c++  java
  • Web-js-10月19日

    1.  函数  关键词function

    复习

    Var 是js的关键字,关于声明变量,声明在内存模块完成,定义(=)实在执行模块完成。

    Var可以在内存模块提前(js代码执行前)完成所有有变量提升这个功能。

    因为a没有带var,所以不存在变量提升,浏览器会把他当成window的属性。

    Function也是js的关键字,用于声明和定义函数的,声明和定义都在内存模块完成了。

    Function 也是内存模块提前完成,所以有函数提升这个功能。

    变量提升和函数提升   ,都叫预解释。都是浏览器的。

    2.函数的定义:函数,具有一定功能的代码块。

      函数是通过function定义的,function后跟的是函数名。

      结构语法

      function fn(){}

    通过上图我们发现,内存模块只存var的变量名。而存function整个代码块,因为声明和定义同时完成的。

    函数结构注意的:

    函数定义   通过function定义   function fn(){}

     函数定义的四种方式:

    1.声明式定义   function  fn(){}

    2.表达式定义   var  an=function(){}  匿名函数

    3.自调用

       定义和调用同时完成

     

    4.通过对象的形式   var as=new  function(){}

    函数调用  函数名()      fn()

      函数最大的优势   会形成一个独立的模块,可以按需使用,可以重复使用。

      按需使用  可以提升性能    重复使用  减少代码冗余。

      函数调用的过程

      函数执行时会形成一个自己的私有作用域。最大的作用域是window(全局作用域)

      然后执行函数里面的代码块。

    案例分析

    分析图

    作用域链:函数内部的变量被使用时,首先会在自己的私有作用域下查找是否有这个变量,有就直接使用,没有就会向他的上一级查找,父级就使用父级的,父级没有就会继续向上查找直到window位置,window有就使用,没有就是is not defined。这种查找机制我们就叫作用域链。

    分析图

    函数归属谁,跟她在哪调用没关系,而是在哪定义有关。

    函数递归:函数内部调用自己。

    Break 和continue运算

    Break 终止当前程序

    Continue  跳出当前的程序,执行下一个。

    Break 和continue只能在循环语句中。如果条件语句想使用break只能使用return。

    return  返回

    每个函数都有一个返回值,如果函数人为return了,返回什么就是什么。

    如果没有人为返回,结果是undefined。并且return后面的代码不在执行了。

    案例分析

    函数内部的return   不影响函数内部的预解释。

    函数内外的变量

       函数外的变量叫全局变量,函数内的变量叫私有变量。

         看变量归谁,看他在哪个作用域下声明。

       私有变量的种类

        1.   在私有作用域下的声明。

        2.通过函数传参的叫私有变量。

    函数传参    arguments   参数

      Function  fn(a,b,c,d){}将abcd叫做参数

      形参:定义上的参数。

      实参:执行上的参数 

  • 相关阅读:
    c++中的工具(一):std::pair<class T1, class T2>
    mybatisplus Lambda 表达式
    将查询结果映射成map的注解,其中第一个字段为key,第二个字段为value.
    mybatisplus 添加 /修改 数据 插入公共字段
    mybatisplus扩展BaseMapper的方法(InsertBatchSomeColumn及AlwaysUpdateSomeColumnById)
    根据俩日期(yyyy-MM-dd)格式获取它们之间的年月日组合结果(js实现)
    oralce json字段中根据key提取value的函数(转载)
    记录一下关于oracle还原数据库的问题
    记录一下数据库外连接 的不同
    JAVA项目从运维部署到项目开发(六. Jenkins之静态页面(2))
  • 原文地址:https://www.cnblogs.com/lovels/p/9817690.html
Copyright © 2011-2022 走看看