15、作用域

概念: 规定变量或函数的可被访问的范围和生命周期

分类: 全局作用域 -就是指当前整个页面环境;

局部作用域(函数作用域) -就是指某个函数内部环境

l 变量的作用域

全局变量 - 定义在全局作用域中的变量;全局变量在任何位置均可访问

局部变量 - 定义在函数作用域中的变量;只能在该函数内访问该变量

  • Ø 全局变量:

var a = ‘A’ ;   ---全局变量                  对比    |     var a = ‘A’;  ---全局变量

function fn ( ){                                   |       function fn ( ){

a=’B’; ---全局变量[不加var, 会自动提升(不推荐)] |       var a=’B’; ---局部变量

console.log(a); // ’B’                              |       console.log(a); // ’B’

}                                              |        }

fn( );                                             |     fn( );

console.log(a); // ’B’                                 |     console.log(a); // ’A’

  • Ø 局部变量

var a = 'A'

function fn( ){

var b = 'B';   // 定义局部变量

console.log(a);  // 输出 A  在局部作用域中访问全局变量a

console.log(b);  // 输出 B  在局部作用域中访问局部变量b

}

fn( );

console.log(b);  // 输出报错  在全局作用域中不可以访问局部变量b

【注:在局部作用域中可以访问全局变量,在全局作用域不可以访问局部变量】

² 按值传递:

将全局变量作为函数的实参传递给函数内部

* 函数的内部只是得到全局变量的值 - 不是全局变量

* 函数的内部操作形参的值时 - 不会影响全局变量

u 函数的作用域:

全局函数 - 定义在全局作用域的函数;

内部(私有)函数 - 定义在函数作用域的函数

全局函数与局部函数的作用域对比

16、特殊函数

匿名函数

概念:没有名的函数(没有名,也就无法调用)   注:语法上不许,编写报错,运行报错

eg: function ( ){                             应用于自调函数和回调函数

console.log('this is function');

}

( );

自调函数

概念:自己调用自己的函数(只能调用一次);        特点:只需要定义即可(定义即调用)

格式: ( )( ); 或 ( ( ) );          ---第一个小括号: 定义函数;第二个小括号: 调用函数

作用:用于优化所有全局变量和函数

eg: ( function(a,b){ console.log('this is song' + a); }) ( 1,2 );  //this is song 1

eg: ( function(a,b){ console.log('this is song' + a); } ( 1,2 ));  //this is song 1

回调函数

概念:函数作为参数传递给另一个函数时,作为参数的函数被称之为回调函数

优点:

*可以在不做命名的情况下传递函数(这意味着可以节省全局变量)。

*可以将一个函数调用操作委托给另一个函数(这意味着可以节省一些代码编写工作)。

*同时也有助于提升性能。

匿名回调函数:匿名函数作为另一个函数的参数出现,即目前只有函数调用才会加( )

作为值的函数

概念:函数A作为函数B的结果进行返回,作为结果返回的函数A称为作为值的函数。

即将内部函数放到return语句

作用:在全局作用域中访问到内部函数   在全局作用域中访问到局部变量

Js基础知识(作用域、特殊函数---自调、回调、作为值的函数)的更多相关文章

  1. JS基础知识笔记

    2020-04-15 JS基础知识笔记 // new Boolean()传入的值与if判断一样 var test=new Boolean(); console.log(test); // false ...

  2. [JS复习] JS 基础知识

    项目结尾,空闲时间,又把<JS 基础知识> 这本书过了一遍,温故知新后,很多知其然不知其所以然的内容 豁然开朗. [1. 用于范围的标签] display  :inline or bloc ...

  3. HTML+CSS+JS基础知识

    HTML+CSS+JS基础知识 目录 对HTML+CSS+JS的理解 基础知识 对HTML+CSS+JS的理解 基础知识 插入样式表的三种方式 外部样式表:<link rel="sty ...

  4. Node.js基础知识

    Node.js入门   Node.js     Node.js是一套用来编写高性能网络服务器的JavaScript工具包,一系列的变化由此开始.比较独特的是,Node.js会假设在POSIX环境下运行 ...

  5. 网站开发进阶(十五)JS基础知识充电站

    JS基础知识充电站 1.javascript alert弹出对话框时确定和取消两个按钮返回值? 用的不是alert对话框,是confirm confirm(str); 参数str:你要说的话或问题: ...

  6. NodeJs>------->>第三章:Node.js基础知识

    第三章:Node.js基础知识 一:Node.js中的控制台 1:console.log.console.info  方法 console.log(" node app1.js 1> ...

  7. JS基础学习——作用域

    JS基础学习--作用域 什么是作用域 变量的作用域就是变量能被访问到的代码范围,比如在下面的这个js代码中,变量a的作用域就是函数foo,因此在全局作用域内的console.log(a)语句不能访问到 ...

  8. 前端JS基础知识

    1. 原型 / 构造函数 / 实例 原型(prototype): 一个简单的对象,用于实现对象的 属性继承.可以简单的理解成对象的爹.在 Firefox 和 Chrome 中,每个JavaScript ...

  9. [Js]基础知识

    一.JavaScript组成 1.ECMAScript 解释器.翻译(提供功能有限,如加减乘除,定义变量.函数等)   几乎没有兼容性问题 2.DOM    有一些兼容性问题 3.BOM(用的少,交互 ...

随机推荐

  1. UBuntu安裝使用PIP

    Windows下安裝python包還是比較方便的,直接在FLD網站下載對應的EXE文件就可以安裝,在linux系統下,使用pip,easy egg 管理工具可以減輕安裝負擔. 原文鏈接:http:// ...

  2. C# 分割URL地址

    public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_C ...

  3. ZBrush快捷键与鼠标操作

    ZBrush是一款3D图形绘制软件,功能十分强大,且比较复杂,除了菜单栏功能按钮,ZBrush还提供了一系列快捷键与鼠标操作,熟练掌握ZBrush快捷键与鼠标操作,可以帮助您大大节省图形创作时间.下面 ...

  4. Java Spring 两大特色

    0 引言 本文主要描述的是Spring常用的两大特色功能:AOP和IoC容器 1 IoC Spring的IoC:就是常说的“控制反转”,也又叫依赖注入的(DI). 优点:IoC最大的好处就是把对象生成 ...

  5. 很详尽KMP算法(厉害)

    作者:July时间:最初写于2011年12月,2014年7月21日晚10点 全部删除重写成此文,随后的半个多月不断反复改进.后收录于新书<编程之法:面试和算法心得>第4.4节中. 1. 引 ...

  6. pyhton的selenium的搭建

    一.好记性不如烂笔头,小伙伴们.让我们做下笔记吧 1.首先要安装pycharm  激活注册码地址:http://idea.lanyus.com/ 2.下载python3.6   python下载地址: ...

  7. js操作url参数

    function getQueStr(url, ref) //获取参数值 { var str = url.substr(url.indexOf('?') + 1); if (str.indexOf(' ...

  8. 洛谷P1567 统计天数

    题目背景 统计天数 题目描述 炎热的夏日,KC非常的不爽.他宁可忍受北极的寒冷,也不愿忍受厦门的夏天.最近,他开始研究天气的变化.他希望用研究的结果预测未来的天气. 经历千辛万苦,他收集了连续N(1& ...

  9. 微信公众号开发之获取微信用户的openID

    (注:openID同一用户同一应用唯一,UnionID同一用户不同应用唯一.不同应用指微信开放平台下的不同用户.) 1.  申请测试号(获得appID.appsecret) 2.  填写服务器配置并验 ...

  10. Problem 7

    Problem 7 # Problem_7.py """ By listing the first six prime numbers: 2, 3, 5, 7, 11, ...