| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> 从函数内变量的访问,到匿名函数和自调用函数 -> 正文阅读 |
|
[JavaScript知识库]从函数内变量的访问,到匿名函数和自调用函数 |
目录 变量的分类:local variables 和 global varibles 在学习函数内定义的变量(local variables局部变量)时,看到有提示:推荐尽可能使用 local variables,不要使用 global variables 全局变量,因为这样可以让代码干净且易于理解 。 见链接:Functions (javascript.info) ?突然想到,这不就是之前看到过的“避免污染全局变量”么,突然一下子茅塞顿开。把之前的项目代码翻来看,突然就理解了之前头疼不已的自调用函数问题。 下面记录一下: 变量的分类:local variables 和 global varibles只有函数内部 和 语句 statements 的{}符号内 的代码属于 block 块级作用域,在这里面声明的变量叫做 local variables 局部变量;除此之外地方声明的变量叫做 global varibles 全局变量。 访问规则是:
因此,可以通过下面第 118 行代码来暴露函数内部的对象 Game,供函数外部调用,让 Game 变为 一个全局变量。 具体做法是:原理:对于一个对象 obj 来说,如果 obj 内部没有属性名 key, 就可以通过赋值的方式添加属性名,即 obj.key = 'something' 。 因此,在这里通过 window.Game = Game,直接给 window 增加了Game这个属性名,让 Game 成为了全局变量,在函数外部也可以被调用。这样就突破了 block 块级作用域 对局部变量 Game的限制。 匿名函数定义函数一般有两种方式:参考链接:JavaScript匿名函数的理解_w3cschool 第一种:function 关键字
第二种:匿名函数
匿名函数的调用匿名函数,即没有函数名的函数,因此不能直接被外部调用,只能通过 赋值 或者 自执行函数 调用。 参考链接:(4条消息) JS 匿名函数——几种不同的调用方式_足各路-CSDN博客_js 匿名函数 ?自调用函数IIFE作用在定义函数的时候就执行函数,因此又叫自执行函数。 它可以封闭作用域,在作用域外无法调用其内部的函数,避免作用域内定义的变量污染全局变量 。比如上图中,就无法在自调用函数外访问 runSnake 等函数(但是由于通过 window.Game = Game 把函数内部的 Game 对象暴露给了外部,因此在外部可以通过 window.Game 访问到局部变量 Game,这样就限定了访问局部变量的方式)。 实现原理通过操作符等各种符号,将匿名函数转换为函数表达式,并添加 () 调用。 常见形式是 (匿名函数)(); ,比如?(function () {})(); 或者? (function foo() {})(); 除了用 () 包裹匿名函数,自执行函数还可以有多种形式:可以在匿名函数前加上操作符。因为操作符可以把 function 关键字转换成函数表达式。比如 +function () {}();? 参考链接:浅谈自执行函数(立即调用的函数表达式) - 简书 (jianshu.com) 句尾要不要加分号JavaScript中可以不写分号,但是多个自调用函数之间,必须加上分号(要么在之前,要么在之后)。否则代码压缩后,上一个函数和自调用函数合并在一起,容易报错。 参数:可不传(function () {parameter1, parameter2})(argument1, argument2); parameter 形参 argument 实参 上图中的参数传了 window 和 undefined,原因是: 传入 window 全局对象,作用:
传入 undefined 作用:在有的老版本的浏览器中undefined可以被重新赋值,这里可以防止undefined被重新赋值。 |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/6 14:02:37- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |