iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > JAVA >JavaScript(函数,作用域和闭包)
  • 638
分享到

JavaScript(函数,作用域和闭包)

前端javascript开发语言 2023-09-05 07:09:08 638人浏览 安东尼
摘要

目录 一,什么是函数1.1,常用系统函数1.2,函数声明 1.3,函数表达式二,预解析2.1,函数自调用 2.2,回调函数三,变量的作用域3.1,隐式全局变量 四,作用域与块级作用

目录

一,什么是函数

类似于Java中的方法,是完成特定任务的代码语句块
特点
使用更简单
不用定义属于某个类,直接调用执行
分类
系统函数
自定义函数

1.1,常用系统函数

1.将字符串转换为整型数字

parseInt("字符串");<body>    <input type="button" value="求和" onclick="qiuhe()"></body><script>var num1 = parseInt("56.64");      //返回值为56var num2 = parseInt("123abc");   //返回值为123var num3 = parseInt("hello999"); //返回值为NaNconsole.log(num1,num2,num3); function qiuhe(){       var n1 = prompt("请输入第一个数")        var n2 = prompt("请输入第二个数")        var num1=parseInt(n1)        var num2=parseInt(n2)        if(isNaN(num1)||isNaN(num2)){            alert("有一个不是数字");        }else{            document.write(num1+num2)        }    }</script>

js示例1

在这里插入图片描述

从下标为0起,依次判断每个字符是否可以转换为一个有效数字
如果不是有效数字,则返回NaN,不再继续执行其他操作
如果是有效数字,则该函数将查看下标为1的字符,进行同样的测试,直到发现非有效数字的字符或全部检测完为止

2.将字符串转换为浮点型数字

parseFloat("字符串");var num1 = parseFloat("3.1415926");  //返回值为3.1415926var num2 = parseFloat("123abc");       //返回值为123var num3 = parseFloat("hello999");     //返回值为NaNvar num4 = parseFloat("52.18.97");     //返回值为52.18 如果有两个小数点则第二个小数点无效console.log(num1,num2,num3);

在这里插入图片描述

3.检查其参数是否是非数字

isNaN(x);var num1=isNaN("20.5");       //返回值为falsevar num2=isNaN("123abc");  //返回值为truevar num3=isNaN(48.98);       //返回值为falseconsole.log(num1,num2,num3);

在这里插入图片描述

通常,使用isNaN()函数检测parseInt()和parseFloat()的运算结果,判断它们表示的是否是合格的数字;也可以使用isNaN()函数检测
操作数是否有错误,例如:用0作为除数的情况

1.2,函数声明

由关键字function、函数名、一组参数及置于括号中的待执行的javascript语句组成

语法

// JavaScript是弱数据类型,对于函数参数没有类型检查和类型限定function 函数名([参数1[, 参数2[, 参数3,] ] ]) {    //JavaScript语句;    [return 返回值] // return可有可无}

调用函数

// 一般和表单元素的事件一起使用事件名=“函数名([参数值1[, 参数值2[, 参数值3,] ])";

函数声明——调用无参函数

// 定义并调用无参函数,输出5次“你好”<body>//单击此按钮时,调用函数func1( ),执行函数体中的代码    <input type="button" value="点我执行" onclick="func1()"></body><script>    function func1(){        for(var i=0;i<5;i++){            document.write("

你好"+i+"

"
) } }</script>

js示例2

函数声明——调用有参函数

// 键盘接受“你好”输出行数,并按指定数字输出到网页 <body>    <input type="button" value="点我执行" onclick="func1(prompt('请输入显示你好的次数:'))"></body><script>    function func1(count){        for(var i=0;i<5;i++){            document.write("

你好"+i+"

"
) } }</script>

js示例3

1.3,函数表达式

将函数赋给变量
定义函数

var 变量 = function([参数值1[, 参数值2[, 参数值3,] ]) {    //JavaScript语句;};

调用函数

变量([参数值1[, 参数值2[, 参数值3,] ]);

函数表达式

 // 使用函数声明的方式定义两个函数名都为f1()的函数     f1();    function f1(){        var num3 = 100;        console.log(num3)    }    function f1(){        console.log("今天天气很好!")    }    f1();    function f1(){        console.log("今天天气好晴天,处处好风光");    }    f1();

在这里插入图片描述

// 使用函数表达式方式定义两个函数名都为f2()的函数    var f2 = function(){        console.log("哇~");    }    f2();    var f2 = function(){        console.log("娃哈哈~");    }    f2();

在这里插入图片描述

使用函数声明方式定义两个同名的函数时,后面的函数将会覆盖前面的函数;
使用函数表达式方式定义同名的函数时,会从上到下,逐行执行代码,并输出结果

二,预解析

顾名思义就是提前解析代码
主要完成两项工作
其一,变量的声明会提前
其二,函数的声明也会被提前

// 预解析可以把变量的声明提前console.log(num); //undefinedvar num=10;// 预解析可以把函数的声明提前f1();function f1() {    var num=100;    console.log(num); //100}

在这里插入图片描述

2.1,函数自调用

自定义函数分类
命名函数
匿名函数

语法

(function() {//函数体    })();

匿名函数的特点
函数没有名字,在声明的同时便直接调用
好处
同名函数之间不会有冲突

    (    function(){        console.log("立即执行函数");    })();

在这里插入图片描述

2.2,回调函数

注意
如果没有指定回调函数的名称,则称之为 匿名回调函数

    function f1(fn){        console.log("f1");        fn()    };    function f2(){        console.log("f2");        return 1    };    f1(f2); // 执行命名回调函数,注意f2后面不能加()

在这里插入图片描述

    function f1(fn){        console.log("f1");        fn()    };    f1(function(){ // 匿名函数        console.log("我没有名字!");    })

在这里插入图片描述

三,变量的作用域

根据变量作用范围不同,分类
局部变量
在函数内部声明的变量(必须使用var)
只能在函数内部访问它
可以在不同的函数中使用名称相同的局部变量
全局变量
在函数外声明的变量
网页的所有脚本和函数都能访问它

    var x = 10;    function f1(){        var y = 5;        console.log(x); // 10        console.log(y); // 5    }    f1();    console.log(x); // 10    console.log(y); // y is not defined

在这里插入图片描述

局部变量与全局变量的区别

区别局部变量全局变量
作用域仅作用在函数中作用在整个脚本
声明位置函数中使用之前的任何位置
生存期在函数运行以后被删除在页面关闭后被删除

3.1,隐式全局变量

如果变量声明时,没有使用关键字var,则被称为隐式全局变量

示例

var a1 = 1;  //全局变量a2 = 2;        //隐式全局变量

如果在函数内部声明变量时,没有使用关键字var,则也是隐式全局变量

    function f1(){        var num = 100;    }    f1();    console.log(num); // 函数会报错

在这里插入图片描述

    function f1(){        num = 100;    }    f1();    console.log(num);

在这里插入图片描述

与解析:
1.会把全局变量的“声明”提前2.提前声明函数,但是函数内部的代码是不执行的局部变量:必须在函数内部使用var/let声明,如果不使用,则称为隐式全局变量隐式全局变量:只有在执行后使用,全局变量和局部变量可以重名,使用就近原则

四,作用域与块级作用域

作用域
是变量与函数的可访问范围
控制着变量与函数的可见性和生命周期
块级作用域
由花括号“ { } ”限定
所有的变量都定义在花括号内
变量从定义开始到花括号结束的范围内可以使用
使用场景
正常带有大括号的语句
条件语句
循环语句
函数

    正常带有大括号的语句    {        var num = 10;    }    console.log(num); // 10    // 条件语句    if(true){        var num = 20;    }    console.log(num); // 20    // 循环语句    for(var i=0;i<5; i++){        var num = 30;    }    console.log(num); // 30    // 函数    function f1(){        var num  = 50;    }    f1();    console.log(num); // num is not defined

五,作用域链

Scope Chain
是JavaScript内部一种变量、函数查找机制
决定了变量和函数的作用范围
当执行函数时,先从函数内部寻找局部变量
如果内部找不到,则向创建函数的作用域寻找,依次向上
如果最终没有找到,通常会报错

    var num = 10; // 

--结束END--

本文标题: JavaScript(函数,作用域和闭包)

本文链接: https://www.lsjlt.com/news/394920.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript(函数,作用域和闭包)
    目录 一,什么是函数1.1,常用系统函数1.2,函数声明 1.3,函数表达式二,预解析2.1,函数自调用 2.2,回调函数三,变量的作用域3.1,隐式全局变量 四,作用域与块级作用...
    99+
    2023-09-05
    前端 javascript 开发语言
  • python基础-内置函数-作用域-闭包
    内置函数-作用域-闭包-递归 1.几个可能用到的内置函数 查看内置函数: print(dir(__builtins__)) 常见函数: len 求长度 min 最小值 max 最大值 sorted 排...
    99+
    2023-01-31
    函数 作用 基础
  • JavaScript 中的作用域与闭包
    目录一、JavaScript 是一门编译语言1.1 传统编译语言的编译步骤1.2 JavaScript 与传统编译语言的区别二、作用域(Scope)2.1 LHS查询 和 RHS查询...
    99+
    2022-11-13
  • Javascript作用域与闭包详情
    目录1、作用域2、作用域链3、词法作用域5、闭包的应用6、闭包的缺陷7、高频闭包面试题1、作用域 简单来说,作用域是指程序中定义变量的区域,它决定了当前执行代码对变量的访问权限 在E...
    99+
    2022-11-12
  • JavaScript 函数闭包的含义和作用是什么
    这篇文章主要讲解了“JavaScript 函数闭包的含义和作用是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript 函数闭包的含义和作用...
    99+
    2022-10-19
  • 基于Python函数的作用域规则和闭包(详解)
    作用域规则 命名空间是从名称到对象的映射,Python中主要是通过字典实现的,主要有以下几个命名空间: 内置命名空间,包含一些内置函数和内置异常的名称,在Python解释器启动时创建,一直保存到解释器退出。...
    99+
    2022-06-04
    详解 函数 规则
  • Javascript的作用域、作用域链以及闭包详解
    一、javascript中的作用域 ①全局变量-函数体外部进行声明 ②局部变量-函数体内部进行声明 1)函数级作用域 javascript语言中局部变量不同于C#、Java等高级语言...
    99+
    2022-11-13
  • JavaScript闭包和作用域链的定义实现
    目录引言闭包的定义和实现作用域链闭包和作用域链的关系使用闭包的注意事项结论引言 在JavaScript中,每个函数都有自己的作用域。作用域规定了哪些变量和函数可以在当前函数内部访问。...
    99+
    2023-05-20
    JavaScript闭包作用域链 JavaScript作用域链
  • 【PHP】函数-作用域&可变函数&匿名函数&闭包&常用系统函数
    文章目录 函数定义&使用命名规则参数种类默认值引用传递函数返回值return关键字 作用域global关键字静态变量 可变函数匿名函数闭包常用系统函数输出函数时间函数数学函数与函数相关...
    99+
    2023-08-31
    php 开发语言
  • Javascript之作用域、作用域链、闭包的示例分析
    这篇文章主要介绍Javascript之作用域、作用域链、闭包的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!什么是作用域?作用域是一种规则,在代码编译阶段就确定了,规定了变量...
    99+
    2022-10-19
  • 在javascript中闭包是不是作用域
    本篇内容介绍了“在javascript中闭包是不是作用域”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-19
  • 【6】装饰器、闭包、偏函数、变量作用域问
            【一】、装饰器思想 装饰器是其实想增加一个函数的功能,但是又不想变动原来函数的代码,就用装饰器。 比如:我们用别人的一个函数,又不是很满意,所以用装饰器装饰一下即可。   def fun1(): print(...
    99+
    2023-01-30
    变量 函数 作用
  • JavaScript的闭包与变量作用域介绍
    这篇文章主要讲解了“JavaScript的闭包与变量作用域介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript的闭包与变量作用域介绍”吧!...
    99+
    2022-10-19
  • Python全栈之作用域和闭包
    目录1.return返回值2.全局变量_局部变量3.函数名的使用4.函数的嵌套4.1函数的嵌套4.2nonlocal的使用5.闭包函数的定义6.闭包的特点_意义小提示:7.小练习总结...
    99+
    2022-11-12
  • JavaScript闭包和匿名函数的关系
    这篇文章主要讲解了“JavaScript闭包和匿名函数的关系”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript闭包和匿名函数的关系”吧!前面...
    99+
    2022-10-19
  • JavaScript全局作用域和函数作用域实例分析
    本篇内容介绍了“JavaScript全局作用域和函数作用域实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有...
    99+
    2022-10-19
  • javascript闭包的概念和作用
    这篇文章主要讲解了“javascript闭包的概念和作用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript闭包的概念和作用”吧!1 闭包--...
    99+
    2022-10-19
  • 一文了解JavaScript闭包函数
    目录变量作用域闭包的概念闭包的用途闭包的缺点最后总结一下闭包的好处与坏处总结变量作用域 要理解JavaScript闭包,就要先理解JavaScript的变量作用域。 变量的作用域有...
    99+
    2022-11-12
  • JavaScript函数闭包实例讲解
    这篇文章主要讲解了“JavaScript函数闭包实例讲解”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript函数闭包实例讲解”吧!首先让我们来...
    99+
    2022-10-19
  • 怎么理解JavaScript闭包函数
    本篇内容介绍了“怎么理解JavaScript闭包函数”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!变量作用域要理解JavaScript闭包,...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作