保安日记:JavaScript学习第十八篇之Javascrip函数进阶

本文主要是介绍保安日记:JavaScript学习第十八篇之Javascrip函数进阶,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

函数进阶

定义方式

1.自定义函数 function fn() {};
2.函数表达式(匿名函数) var fun = function() {};
3.利用 new Function(‘参数1’,‘参数2’,‘函数体’);

----所有函数都是 Function 的实例(对象)

var fun = new Function('a','b','console.log(a + b)');
fun(1,2);

调用方式

1. 普通函数function fn() {console.log('人生的巅峰');}// fn();   fn.call()
2. 对象的方法var o = {sayHi: function() {console.log('人生的巅峰');}}o.sayHi();
3. 构造函数function Star() {};new Star();
4. 绑定事件函数btn.onclick = function() {};   // 点击了按钮就可以调用这个函数
5. 定时器函数setInterval(function() {}, 1000);  //这个函数是定时器自动1秒钟调用一次
6. 立即执行函数(function() {console.log('人生的巅峰');})();// 立即执行函数是自动调用

this指向

    <script>
函数的不同调用方式决定了this 的指向不同
1. 普通函数 this 指向windowfunction fn() {console.log('普通函数的this' + this);}window.fn();
2. 对象的方法 this指向的是对象 ovar o = {sayHi: function() {console.log('对象方法的this:' + this);}}o.sayHi();
3. 构造函数 this 指向 ldh 这个实例对象 原型对象里面的this 指向的也是 ldh这个实例对象function Star() {};Star.prototype.sing = function() {}var ldh = new Star();
4. 绑定事件函数 this 指向的是函数的调用者 btn这个按钮对象var btn = document.querySelector('button');btn.onclick = function() {console.log('绑定时间函数的this:' + this);};
5. 定时器函数 this 指向的也是windowwindow.setTimeout(function() {console.log('定时器的this:' + this);}, 1000);
6. 立即执行函数 this还是指向window(function() {console.log('立即执行函数的this' + this);})();</script>
改变函数内部this指向
  1. call()

     var o = {name: 'andy'}function fn(a, b) {console.log(this);console.log(a + b);};fn.call(o, 1, 2);
    call 第一个可以调用函数 第二个可以改变函数内的this 指向
    call 的主要作用可以实现继承function Father(uname, age) {this.uname = uname;this.age = age;}function Son(uname, age) {Father.call(this, uname, age);}var son = new Son('刘德华', 18);console.log(son);
    
  2. apply()

    fn.apply(thisArg,[argsArray])
    thisArg----在fn函数运行时指定的this值
    [argsArray]----传递的值,必须包含在数组里
    返回值就是函数的返回值
    
     var o = {name: 'andy'};function fn(arr) {console.log(this);console.log(arr); // 'pink'};fn.apply(o, ['pink']);
    1. 也是调用函数 第二个可以改变函数内部的this指向
    2. 但是他的参数必须是数组(伪数组)---'[]'
    3. apply 的主要应用 比如说我们可以利用 apply 借助于数学内置对象求数组最大值 var arr = [1, 66, 3, 99, 4];var arr1 = ['red', 'pink'];var max = Math.max.apply(Math, arr);var min = Math.min.apply(Math, arr);console.log(max, min);
    
  3. bind()

    fn.bind(thisArg,arg1,arg2...)
    thisArg----在fn函数运行时指定的this值
    arg1,arg2..----传递的其他参数
    
     var o = {name: 'andy'};function fn(a, b) {console.log(this);console.log(a + b);};var f = fn.bind(o, 1, 2);f();
    1. 不会调用原来的函数   可以改变原来函数内部的this 指向
    2. 返回的是原函数改变this之后产生的新函数
    3. 如果有的函数我们不需要立即调用,但是又想改变这个函数内部的this指向此时用bind
    4. 我们有一个按钮,当我们点击了之后,就禁用这个按钮,3秒钟之后开启这个按钮/*var btn1 = document.querySelector("button");btn1.onclick = function () {this.disabled = true; // 这个this 指向的是 btn 这个按钮// var that = this;setTimeout(function () {// that.disabled = false; // 定时器函数里面的this 指向的是windowthis.disabled = false; // 此时定时器函数里面的this 指向的是btn}.bind(this),3000); // 这个this 指向的是btn 这个对象};*/var btns = document.querySelectorAll('button');for (var i = 0; i < btns.length; i++) {btns[i].onclick = function() {this.disabled = true;setTimeout(function() {this.disabled = false;}.bind(this), 2000);}}
    
    总结

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Uqc4oIW5-1604125134341)(C:\Users\97169\AppData\Roaming\Typora\typora-user-images\image-20201031134826654.png)]

严格模式—strict mode

在这里插入图片描述

开启严格模式
  1. 为脚本开启严格模式
<script>'use strict'; //---js代码就会按照严格模式执行代码
</script>
  1. 为函数开启严格模式
function() {'use strict';
}
严格模式的变化

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

这篇关于保安日记:JavaScript学习第十八篇之Javascrip函数进阶的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/197786

相关文章

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与