1、New Function

  语法:let func = new Function ([arg1[, arg2[, ...argN]],] functionBody)

  //无参数示例:

  let sayHi = new Function('alert ("Hello")');

  sayHi();//Hello

  //有参数示例

  let sum = new Function('a','b','return a + b');

  alert(sum(1,2));//3

2、调度:setTimeout 和 setInterval

  setTimeout 将函数的执行推迟到一段时间后再执行

  setInterval 让函数间隔一定时间周期性执行

  setTimeout 语法:let timerId = setTimeout(func|code, delay[, arg1, arg2...])

  func|code  想要执行的代码或者代码字符串

  delay:执行前的延时 单位为毫秒

  arg1,arg2..:参数列表,ie9 以下不支持

  无参数示例

  function sayHi(){

    alert('hello');

  }

  setTimeout(sayHi,1000);//1秒后执行

  带参数示例

  function sayHi(pthrase,who){

    alert(phrase+','+who);  

  }

  setTimeou(sayHi,1000,"Hello","Jhon");//Hello,John

  箭头函数的形式

  setTimeout(()=>alert('hello'));

  用claerTimeout 来取消调度

  setTimeout 在调用时会返回一个定时器id

  cleatTimeout 使用的方法

  let timerId = setTimeout(....);

  clearTimeout(timerId);

  示例:

 let timerId = setTimeout(() => alert("never happens"), );
alert(timerId); // 定时器 id clearTimeout(timerId);
alert(timerId); // 还是那个 id 没变(并没有因为调度被取消了而变成 null)

  setInterval

  语法: let timerId = setInterVal(func|code,delay,[,arg1,arg2...])

  用法和setTimeout 相同,但是执行的方式不一样,这个是每间隔相同的时间执行一次。

  递归版 setTimeout

  

 let i = ;
setInterval(function() {
func(i);
}, ); let i = ;
setTimeout(function run() {
func(i);
setTimeout(run, );
}, );

  setTimeout(...,0);

  这种用法,虽然时间为0,但是还是会被延时执行,放到一般函数后执行

3、装饰和转发,call/apply

 1) 使用“func.call" 作为上下文

  语法: func.call(context,arg1,arg2,...)  

 function sayHi() {
alert(this.name);
} let user = { name: "John" };
let admin = { name: "Admin" }; // 使用 call 将不同的对象传递为 "this"
sayHi.call( user ); // this = John
sayHi.call( admin ); // this = Admin

  

 function say(phrase) {
alert(this.name + ': ' + phrase);
} let user = { name: "John" }; // user becomes this, and "Hello" becomes the first argument
say.call( user, "Hello" ); // John: Hello
 let worker = {
someMethod() {
return ;
}, slow(x) {
alert("Called with " + x);
return x * this.someMethod(); // (*)
}
}; function cachingDecorator(func) {
let cache = new Map();
return function(x) {
if (cache.has(x)) {
return cache.get(x);
}
let result = func.call(this, x); // "this" 现在被正确的传递了
cache.set(x, result);
return result;
};
} worker.slow = cachingDecorator(worker.slow); // 现在让他缓存起来 alert( worker.slow() ); // 生效了
alert( worker.slow() ); // 生效了, 不会调用原始的函数了。被缓存起来了 为了清楚地说明,让我们更深入地了解 this 是如何传递的:
在经过装饰之后,worker.slow 现在是包装器 function (x) { ... }。
因此,当执行 worker.slow() 时,包装器将 作为参数并且 this=worker(它是点之前的对象)。
在包装器内部,假设结果尚未缓存,func.call(this, x) 将当前的 this (=worker) 和当前参数 (=)
传递给原始方法。

  2)使用"func.apply" 来传递多参数

   语法:func.apply(context,args)

  

 function say(time, phrase) {
alert(`[${time}] ${this.name}: ${phrase}`);
} let user = { name: "John" }; let messageData = ['10:00', 'Hello']; // 成为时间和短语 // user 成为 this,messageData 作为参数列表传递 (time, phrase)
say.apply(user, messageData); // [10:00] John: Hello (this=user)

4、函数绑定

  丢失this

  在JavaScript中this很容易就会丢失。一旦一个方法被传递到另一个对象分离的地方-----this就会丢失

  丢失示例:

  let user = {

    firstName:"Jhon",

    sayHi(){

      alert(`Hello,${this.firstName}!`);

    }

  };

  setTimeout(user.sayHi,1000);//Hello,undefined!

  这种情况下上下文丢失

  解决方案一:包装层

  let user = {

    firstName:"John",

    sayHi(){

      alert(`Hello,${this.firstName}!`);

    }

  };

  setTimeout(function(){

    user.sayHi();//Hello,Jhon!

  },1000);

  这种方式存在一种风险,就是在1秒之内如果user被改之后,操作的user可能就不是之前的

  解决方案二:bind

  基本的语法: let boundFunc = func.bind(context); 

  func.bind(context) 的结果是一个特殊的像函数一样的“外来对象”,它可以像函数一样被调用并且透明的将 调用传递给 func 并设置 this=context

  换句话说,调用 boundFunc 就像是调用 func 并且固定住了 this。 

  举个例子,这里 funcUser 将调用传递给了 func 同时 this=user

 let user = {
firstName: "John"
}; function func() {
alert(this.firstName);
} let funcUser = func.bind(user);
funcUser(); // John

  处理对象的方法

 let user = {
firstName: "John",
sayHi() {
alert(`Hello, ${this.firstName}!`);
}
}; let sayHi = user.sayHi.bind(user); // (*) sayHi(); // Hello, John! setTimeout(sayHi, ); // Hello, John!

  

javaScript 基础知识汇总 (十)的更多相关文章

  1. javaScript 基础知识汇总 (十二)

    1.属性的标志和描述符 属性的标志 对象属性除value外还有三个特殊属性,即标志 writable ----如果为true,则可以修改,否则它只是只读的. enumerable ----如果为tru ...

  2. javaScript 基础知识汇总 (十五)

    1.模块简介 什么是模块: 模块就是一个文件,一个脚本,通过关键字export 和 import 交换模块之间的功能. export 关键字表示在当前模块之外可以访问的变量和功能. import 关键 ...

  3. javaScript 基础知识汇总 (十四)

    1.回调 什么是回调? 个人理解,让函数有序的执行. 示例: function loadScript(src,callback){ let script = document.createElemen ...

  4. JavaScript基础知识汇总

    1. 图片热区: <img src="logo.jpg" usemap="#logo"> <map id="logo" n ...

  5. javaScript 基础知识汇总(三)

    1.循环:while 和 for while 循环 while(condition){ //代码 循环体 } do ... while  循环 let i =0; do { //循环体 }while( ...

  6. javaScript 基础知识汇总(六)

    1.基本类型与对象的区别 基本类型:是原始类型的中的一种值. 在JavaScript中有6中基本类型:string number  boolean  symbol  null  undefined 对 ...

  7. javaScript 基础知识汇总(五)

    1.垃圾回收 JavaScript 的内存管理是自动的,不能强制执行或者阻止执行 可达性 JavaScript中主要的内存管理概念是可达性. 什么是可达性? 定义一个对象 let user = { n ...

  8. javaScript 基础知识汇总(二)

    1.运算符 术语或者叫法:一元运算符.二元运算符.运算元(参数) let x=0; x=5+2; //5和2为运算元,“+” 为二元运算符: x=-x; //"-" 为一元运算符 ...

  9. javascript 基础知识汇总(一)

    1.<script> 标签 1) 可以通过<script> 标签将javaScript 代码添加到页面中 (type 和language 属性不是必须的) 2)外部的脚本可以通 ...

随机推荐

  1. java异常分析;剖析printStackTrace和fillInStackTrace

    Java异常的栈轨迹(Stack Trace) 捕获到异常时,往往需要进行一些处理.比较简单直接的方式就是打印异常栈轨迹Stack Trace.说起栈轨迹,可能很多人和我一样,第一反应就是printS ...

  2. CRISPR/Cas9|InParanoid|orthoMCL|PanOCT|pan genome|meta genome|Core gene|CVTree3|

    生命组学: 泛基因组学:用于描述一个物种基因组,据细菌基因组动力学,因为细菌的基因漂移使得各个细菌之间的基因组差异很大,(单个细菌之间的基因组差异是以基因为单位的gain&loss,而人类基因 ...

  3. 在Docker内安装jenkins运行和基础配置

    这里是在linux环境下安装docker之后,在doucer内安装jenkins --------------------docker 安装 jenkins---------------------- ...

  4. 一、HTTP和HTTPS的基本概念

    1HTTP:是互联网上应用最为广泛的一种网络协议,是一个客户端和服务器端请求和应答的标准(TCP),用于从WWW服务器传输超文本到本地浏览器的传输协议,它可以使浏览器更加高效,使网络传输减少. 2HT ...

  5. angular知识点(2)

    angular知识点(2) 1.为了代码规范,对于需要自动加载的依赖,需要在前面加上注释,注释为://@ngInject 或者是/*@ngInject*/ 2.ngSwitch的应用 在需要用到选择出 ...

  6. 论文笔记[Slalom: Fast, Verifiable and Private Execution of Neural Networks in Trusted Hardware]

    作者:Florian Tramèr, Dan Boneh [Standford University] [ICLR 2019] Abstract 为保护机器学习中隐私性和数据完整性,通常可以利用可信 ...

  7. 万达乐园VS阿里帝国 谁将是未来娱乐产业的龙头?

    国内实体行业大佬王健林和互联网行业巨头马云,这次又不约而同地想到一块去了.从王健林叫板迪士尼大搞借势营销,到最近马云成立大文娱工作领导小组,明显的趋势表明娱乐越来越成为各界大佬们未来掘金的新战场.只不 ...

  8. 记一次手机与PC同步开发Android项目

    目录 -1 前言 0.0 流程简介 1.0 AS创建项目并上传GitHub 2.0 AIDE克隆GitHub项目 能力不足时曲线救国 > 3.0 termux编译AIDE目录下的项目文件 3.1 ...

  9. pyteeseract使用报错Error: one input ui-file must be specified解决

    Python在图像识别有天然的优势,今天使用pytesseract模块时遇到一个报错:“Error: one input ui-file must be specified”. 环境:windows ...

  10. 使用 Hexo 创建项目文档网站

    当我们发布一个开源项目的时候,最重要的事情之一就是要创建项目文档.对使用项目的用户来说,文档是非常有必要的,通常我们可以使用下面这些方式来创建文档: GitHub Wiki:在 Github 上我们可 ...