【JavaScript】关键字function的点滴

文章目录

        • 1. function与类Function的区别
        • 2. 函数的等价写法
        • 3. 函数的使用场景
        • 4. 两个不同使用场景下的this关键字
        • 5. 面向对象中的继承实现:prototype关键字
        • 6. 理解闭包

1. function与类Function的区别
  • Function 用于直接执行定义的javascript代码
Function(console.log('Hello,Jim!'));
new Function(console.log('Hello,Jim!'));
  • function用于定义函数或者(详见下面描述)
2. 函数的等价写法

当我们需要实现某个功能(如登录)的时候,我们可能会定义一下函数

function login(usrname,password){
}

上面的写法等价于全局定义了一个function类型的login变量

var login = function(usrname,password){
}

ES6之后,引进了箭头函数,我们可以写成一下形式(注意:普通函数跟箭头函数有一些的区别)

var login = (usrname,password)=>{
}
3. 函数的使用场景
  • 作为实现某个功能的函数
login('Jim','123456');// 直接调用
  • 定义面向对象中的类
new login();// 借助new关键字
4. 两个不同使用场景下的this关键字
  • function内第一个局部变量是this,this在不同的使用场景下,指向的对象不一样
var TestThis = function(){if(this instanceof Window){console.log('Window')}if(this instanceof TestThis){console.log('TestThis')}
};
TestThis();// Window
new TestThis();// ThisTest
  • 箭头函数不可以使用new,函数中的this指向Window(除非箭头函数被Function包裹直接执行)
var TestThisByArrowFunc = ()=>{if(this instanceof Window){console.log('Window')}if(this instanceof TestThisByArrowFunc){console.log('TestThisByArrowFunc')}
}
// 没有 ojbect类型的 prototype无法使用instanceof
TestThisByArrowFunc();// Window + Uncaught TypeError: Function has non-object prototype 'undefined' in instanceof check
//没有构造器无法使用new
new TestThisByArrowFunc();// VM742:1 Uncaught TypeError: TestThisByArrowFunc is not a constructorvar myFunc = ()=>{console.log(this};
Function(myFunc()) // Window
5. 面向对象中的继承实现:prototype关键字
  • function 定义基本类跟类实例变量
  • prototype 定义共享方法以提高性能,通过原型链实现方法继承
  • apply/call 将子类的this指针传给父类,让父类的实例变量赋值给子类
// 父类定义
var Person = function(name,age){this.name = name;this.age = age;
}
Person.prototype.toString = function(){console.log(this);
}
// 子类定义
var Teacher = function(name,age,subject){Person.call(this,name,age) // 将子类this指针替换掉父类this,让父类为子类添加字段值this.subject = subject;
}
Teacher.prototype = Object.create(Person.prototype); // 创建中间原型实例
Teacher.prototype.constructor = Teacher; // 修改原型实例构造函数为子类// 测试
var teacher = new Teacher('Jim',35,'Math');
console.log(teacher.name) // Jim
console.log(teacher.age) // 35
console.log(teacher.subject) // Math
teacher.toString() // Teacher {name: 'Jim', age: 35, subject: 'Math'}
console.log(teacher instanceof Person) // true
console.log(teacher instanceof Teacher) // true
  • 上面例子,通过Object.create创建中间原型实例
var tmpPrototype = Object.create(prototype)
等价下面写法
var create = function(prototype){function func(){}func.prototype = prototype;return new func
}
var tmpPrototype = create(prototype)
6. 理解闭包
  • 定义:能够访问到函数级别变量的函数成为闭包,函数级别的变量相对于闭包而已是静态变量
  • 通过实现一个计数器来理解闭包
var counter = function(){counts = 0; //函数级别 静态变量 return function(){ // 返回闭包counts++;console.log(counts)}
}
var myCounter = counter();
myCounter() // 1
myCounter() // 2
myCounter() // 3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/143563.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

竞赛选题 深度学习的智能中文对话问答机器人

文章目录 0 简介1 项目架构2 项目的主要过程2.1 数据清洗、预处理2.2 分桶2.3 训练 3 项目的整体结构4 重要的API4.1 LSTM cells部分:4.2 损失函数:4.3 搭建seq2seq框架:4.4 测试部分:4.5 评价NLP测试效果:4.6 梯度截断…

互联网Java工程师面试题·微服务篇·第一弹

目录 ​编辑 1、您对微服务有何了解? 2、微服务架构有哪些优势? 3、微服务有哪些特点? 4、设计微服务的最佳实践是什么? 5、微服务架构如何运作? 6、微服务架构的优缺点是什么? 7、单片&#xff0c…

vue请求代理查看真实地址

查看真实地址方式: 通过配置vue.config.js文件,直接在请求头输出完整地址: /api/: { changeOrigin: true, target: process.env.VUE_APP_PLATFORM_URL, logLevel: debug, // 在终端输出 onProxyRes(proxyR…

【开题报告】基于SpringBoot的教资考试学习平台的设计与开发

1.选题背景 教资考试是指为了选拔和评价教师专业素质而设立的一系列考试,包括教师资格证考试、教师招聘考试等。这些考试对于教师的职业发展和晋升至关重要。然而,教资考试的内容庞杂且繁琐,学习者需要进行大量的知识积累和复习备考。 当前…

戴建业作品集读书笔记

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、高贵既不屈己从人,也不强人同己君子之交淡如水鄙弃世俗功利,以审美的态度应世观物,不仅美化了平凡的事务,也诗化…

mysql添加外键

要在MySQL中添加外键,你需要执行以下步骤: 创建表:首先,你需要创建包含外键的表和引用的表。假设你有两个表,一个是主表(包含主键),另一个是从表(包含外键)。…

2023/11/15JAVA学习

如何多开一个程序

modbus-RTU是一种比较简单、可靠的协议

modbus-RTU是一种比较简单、可靠的协议 RTU, 是modbus中的一种应用层协议,在OSI的第七层 数据格式 应用

CSS 属性学习笔记(入门)

1. 选择器 CSS选择器用于选择要样式化的HTML元素。以下是一些常见的选择器&#xff1a; 元素选择器 p {color: blue; }描述&#xff1a; 选择所有 <p> 元素&#xff0c;并将文本颜色设置为蓝色。 类选择器 .highlight {background-color: yellow; }描述&#xff1a;…

day2324_jdbc

今日内容 零、 复习昨日 一、作业 二、SQL注入 三、PreparedStatement 四、事务 五、DBUtil 零、 复习昨日 一、引言 1.1 如何操作数据库 使用客户端工具访问数据库&#xff0c;需要手工建立连接&#xff0c;输入用户名和密码登录&#xff0c;编写 SQL 语句&#xff0c;点击执行…

Java设计模式-结构型模式-适配器模式

适配器模式 适配器模式应用场景案例类适配器模式对象适配器模式接口适配器模式适配器模式在源码中的使用 适配器模式 如图&#xff1a;国外插座标准和国内不同&#xff0c;要使用国内的充电器&#xff0c;就需要转接插头&#xff0c;转接插头就是起到适配器的作用 适配器模式&…

Ansible playbook详解

playbook是ansible用于配置&#xff0c;部署&#xff0c;和被管理被控节点的剧本 playbook常用的YMAL格式&#xff1a;&#xff08;文件名称以 .yml结尾&#xff09; 1、文件的第一行应该以 "---" (三个连字符)开始&#xff0c;表明YMAL文件的开始。    2、在同一…

C# 将PDF文档转换为Word文档

一.开发框架&#xff1a; .NetCore6.0 工具&#xff1a;Visual Studio 2022 二.思路&#xff1a; 1.使用SHA256Hash标识文档转换记录&#xff0c;数据库已经存在对应散列值&#xff0c;则直接返还已经转换过的文档 2.数据库没有对应散列值记录的话&#xff0c;则保存上传PDF…

OpenHarmony Promise详解

一&#xff0c;定义 作为一个android开发人员&#xff0c;刚接触Promise可能不好理解&#xff0c;因为android中的异步操作都是开启线程操作或者kotlin的协程&#xff0c;但是Promise并不是单独去开启一个线程来处理异步任务&#xff0c;它是在同一个线程中去处理异步任务。异…

最小花费——最短路

在 n 个人中&#xff0c;某些人的银行账号之间可以互相转账。这些人之间转账的手续费各不相同。给定这些人之间转账时需要从转账金额里扣除百分之几的手续费&#xff0c;请问 A 最少需要多少钱使得转账后 B 收到 100 元。 输入格式 第一行输入两个正整数 n,m&#xff0c;分别表…

性能测试 —— Jmeter分布式测试的注意事项和常见问题

Jmeter是一款开源的性能测试工具&#xff0c;使用Jmeter进行分布式测试时&#xff0c;也需要注意一些细节和问题&#xff0c;否则可能会影响测试结果的准确性和可靠性。 Jmeter分布式测试时需要特别注意的几个方面 1. 参数化文件的位置和内容 如果使用csv文件进行参数化&…

力扣labuladong——一刷day33

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、力扣652. 寻找重复的子树 前言 前序位置的代码只能从函数参数中获取父节点传递来的数据&#xff0c;而后序位置的代码不仅可以获取参数数据&#xff0c;还可…

java算法学习索引之动态规划

一 斐波那契数列问题的递归和动态规划 【题目】给定整数N&#xff0c;返回斐波那契数列的第N项。 补充问题 1&#xff1a;给定整数 N&#xff0c;代表台阶数&#xff0c;一次可以跨 2个或者 1个台阶&#xff0c;返回有多少种走法。 【举例】N3&#xff0c;可以三次都跨1个台…

python循环队列

1.循环队列简介&#xff1a; 循环队列是一种队列的实现方式&#xff0c;它可以避免队列空间的浪费。循环队列的特点是队列的末尾连接到队列的开头&#xff0c;形成一个循环。这样当队列尾部元素达到队列的最大容量时&#xff0c;新的元素可以循环地放入队列的开头。这种设计使…

Linux使用Docker完整安装Superset,同时解决please use superset_config.py to override it报错

文章目录 Docker安装Superset流程1. 首先获取镜像2. 生成SSL3. 创建Superset容器4. 更新数据库5. 测试访问Superset Docker安装Superset流程 1. 首先获取镜像 docker pull amancevice/superset2. 生成SSL 接下来我们运行一些额外的程序&#xff1a; openssl rand -base64 4…