首页 > 其他分享 >js 函数行为分析

js 函数行为分析

时间:2022-11-17 00:23:26浏览次数:48  
标签:function console log name js foo 行为 函数

一、function 关键字

 1 // 定义一个具名函数
 2 function foo() {}
 3 console.log(foo); // ƒ foo() {}
 4 console.log(foo.name); // foo
 5 
 6 // foo 赋值给一个变量
 7 const fuu = foo;
 8 console.log(fuu.name); // foo /* 具名函数的 name 不会改变 */
 9 
10 // 赋值给 foo
11 foo = 1;
12 console.log(foo); // 1 /* function 声明的标识符可以被赋值 */
13 
14 // var 再次声明 foo
15 var foo = 2;
16 console.log(foo); // 2 /* 解析器发现有 foo 的存在,var 关键词被忽略了,但是仍然赋值 */
17 
18 //let 再次声明 foo
19 // let foo = 3; // Uncaught SyntaxError: Identifier 'foo' has already been declared /* 解析阶段报错,全部代码无法运行 */
20 // console.log(foo);

二、function 与 var 的优先级

1 var bar = 1;
2 function bar() {}
3 
4 console.log(bar); // 1 /* 说明 function 优先级高 */

三、匿名函数与对象方法简写

 1 const baz = {
 2     // 简写
 3     getInfo() {},
 4 };
 5 console.log(baz.getInfo); // ƒ getInfo() {} /* 对象方法简写有函数名 */
 6 console.log(baz.getInfo.name); // getInfo /* name 就是对象方法名 */
 7 
 8 // 匿名函数
 9 console.log(function () {}); // ƒ () {} /* 匿名函数不带函数名 */
10 console.log(function () {}.name); // '' /* 也没有 name 值 */
11 
12 // 匿名函数赋值给变量
13 const cat = function () {};
14 console.log(cat); // ƒ () {} /* 匿名函数不带函数名 */
15 console.log(cat.name); // cat /* 但是赋值给变量后,name 有值了 */
16 
17 // 再次赋值给另一个变量
18 const lion = cat;
19 console.log(lion.name); // cat /* 说明具名函数和匿名函数的 name 都只能初始化 */

四、new 关键字

 1 // 常规使用
 2 function Duck() {}
 3 const duck = new Duck();
 4 console.log(duck); // Duck {}
 5 
 6 // 返回值为简单数据类型
 7 function Dog() {
 8     return 1;
 9 }
10 const dog = new Dog();
11 console.log(dog); // Dog {} /* 返回值为简单数据类型时,会被忽略掉 */
12 
13 // 返回值为复杂数据类型
14 let _this = null;
15 function Horse() {
16     _this = this;
17     return {};
18 }
19 const horse = new Horse();
20 console.log(horse); // {} /* 返回值为复杂数据类型时,则返回 */
21 console.log(_this); // Horse {} /* new 仍然构建了对象,只是没返回 */

标签:function,console,log,name,js,foo,行为,函数
From: https://www.cnblogs.com/aurora-power/p/16898066.html

相关文章

  • moment.js使用
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"/><metahttp-equiv="X-UA-Compatible"content="IE=edge"/><metaname="viewport"c......
  • js常用方法总结
    数组方法1letfruits=["Banana","Orange","Apple","Mango"];2//获取数组长度3fruits.length;//44//toString()把数组转换为数组值(逗号分隔......
  • php的几种输出函数
    php输出函数函数名功能描述echo()输出字符串print()输出一个或多个字符串print_r()打印关于变量的易于理解的信息printf()输出格式化字符串sprintf()......
  • nodejs dayjs 时间戳转化时间格式
    Unix时间戳day.js可以轻松转换秒级和毫秒级时间戳:dayjs().unix();//秒dayjs().valueOf();//毫秒letss=dayjs.unix('1668580898').format('YYYY-MM-DDHH:mm:ss'......
  • excel vlookup函数的使用方法
    1.语法说明 参数说明Lookup_value为需要在数据表第一列中进行查找的值。Lookup_value可以为数值、引用或文本字符串。当vlookup函数第一参数省略查找值时,表示用0查......
  • 关于scanf函数不能在某些vs编译器中用的问题
    scanf在vs2022中是一个不安全的函数,vs自定义scanf_s是一个安全的函数,但是这在转给其他编译器可能不适用我们可以在开头加上一个#define_CRT_SECURE_NO_WARNINGS1可以解......
  • 回调函数4
    一、什么是回调函数  回调函数是指使用者自己定义一个函数,实现这个函数的程序内容,然后把这个函数(入口地址)作为参数传入别人(或系统)的函数中,由别人(或系统)的函数在运行时......
  • P4054 [JSOI2009] 计数问题
    传送门二维树状数组板子题(大概?)只要再多开一维\(c\)来存储该点的权值就可以了。这里的树状数组\(a[i][j][c]\)表示以第\(i\)行,第\(j\)列为右下角,权值为\(c\)的点......
  • go语言的内外函数(闭包结构)
    packagemainimport"fmt"/*一个外层函数中,有内层函数,该函数中,会操作外层函数的局部变量并且该外层函数的返回值就是这个内层函数这个内层函数和外层函数的局部变量,统称为......
  • C++走向远洋——34(友元函数,成员函数和一般函数的区别)
    */*Copyright(c)2016,烟台大学计算机与控制工程学院*Allrightsreserved.*文件名:youyuan.cpp*作者:常轩*微信公众号:Worldhello*完成日期:2016年4月10日*版本......