首页 web前端 js教程 javaScript中的this示例学习详解及工作原理_基础知识

javaScript中的this示例学习详解及工作原理_基础知识

May 16, 2016 pm 05:04 PM
工作原理

this的工作原理

如果一个函数被作为一个对象的方法调用,那么this将被指派为这个对象。

复制代码 代码如下:

var parent = {
    method: function () {
        console.log(this);
    }
};

parent.method();
//


注意这种行为非常“脆弱”,如果你获取一个方法的引用并且调用,那么this的值不会是parent了,而是window全局对象。这让大多数开发者迷惑。

复制代码 代码如下:

ThisClownCar();
//  

改动this

.call、 .apply 和.bind 方法用来操作调用函数的方式,帮我们定义this的值和传递给函数的参数值。

Function.prototype.call 可以有任意数量的参数,第一个参数被分配给this,剩下的被传递给调用函数。

复制代码 代码如下:

Array.prototype.slice.call([1, 2, 3], 1, 2)
//
Function.prototype.apply 的行为和.call类似,但它传递给函数的参数是一个数组,而不是任意参数。

String.prototype.split.apply('13.12.02', ['.'])
//  

Function.prototype.bind 创建一个特殊的函数,该函数将永远使用传递给.bind的参数作为this的值,以及能够分配部分参数,创建原函数的珂里化(curride)版本。

 

复制代码 代码如下:

var arr = [1, 2];
var add = Array.prototype.push.bind(arr, 3);

// effectively the same as arr.push(3)
add();

// effectively the same as arr.push(3, 4)
add(4);

console.log(arr);
//


作用域链中的this

在下面的例子,this将无法在作用域链中保持不变。这是规则的缺陷,并且常常会给业余开发者带来困惑。

复制代码 代码如下:

function scoping () {
  console.log(this);

  return function () {
    console.log(this);
  };
}

scoping()();
// //

有一个常见的方法,创建一个局部变量保持对this的引用,并且在子作用域中不能有同命变量。子作用域中的同名变量将覆盖父作用域中对this的引用。http://www.cnblogs.com/sosoft/

复制代码 代码如下:

function retaining () {
  var self = this;

  return function () {
    console.log(self);
  };
}

retaining()();
//  

除非你真的想同时使用父作用域的this,以及当前this值,由于某些莫名其妙的原因,我更喜欢是使用的方法.bind函数。这可以用来将父作用域的this指定给子作用域。

 

复制代码 代码如下:

function bound () {
  return function () {
    console.log(this);
  }.bind(this);
}

bound()();
//
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

SOL币是什么?SOL币的工作原理是什么? SOL币是什么?SOL币的工作原理是什么? Mar 16, 2024 am 10:37 AM

Solana区块链和SOL代币Solana是一种专注于为去中心化应用程序(dApps)提供高性能、安全和可扩展性的区块链平台。SOL代币作为Solana区块链的原生资产,主要用于支付交易手续费、质押和参与治理决策。Solana的独特之处在于其快速的交易确认时间和高吞吐量,使其成为开发者和用户青睐的选择。通过SOL代币,用户可以参与Solana生态系统的各种活动,并共同推动平台的发展和进步。Solana的工作原理Solana采用一种创新的共识机制,被称为历史证明(PoH),能够有效处理数千笔交易。

Spring Data JPA 的架构和工作原理是什么? Spring Data JPA 的架构和工作原理是什么? Apr 17, 2024 pm 02:48 PM

SpringDataJPA基于JPA架构,通过映射、ORM和事务管理与数据库交互。其存储库提供CRUD操作,派生查询简化了数据库访问。此外,它使用延迟加载,仅在必要时检索数据,从而提高了性能。

Polygon币是什么?Polygon币的工作原理是什么? Polygon币是什么?Polygon币的工作原理是什么? Mar 16, 2024 am 09:22 AM

Polygon:构建以太坊生态系统的多功能区块链Polygon是一个建立在以太坊之上的多功能区块链平台,原名为MaticNetwork。其目标是解决以太坊网络中的可扩展性、高费用和复杂性问题。Polygon通过提供可扩展性解决方案,为开发者和用户提供更快速、更便宜、更简单的区块链体验。Polygon的工作原理如下:侧链网络:Polygon创建了一个由多个侧链组成的网络。这些侧链与以太坊主链并行运行,可以处理大量交易,从而提高整体网络吞吐量。Plasma框架:Polygon利用Plasma框架,这

VET币是什么?VET币的工作原理是什么? VET币是什么?VET币的工作原理是什么? Mar 16, 2024 am 11:40 AM

VET币:基于区块链的物联网生态系统VeChainThor(VET)是一种基于区块链技术的平台,旨在通过确保数据的可信性和实现价值的安全转移来提升物联网(IoT)领域的供应链管理和业务流程。VET币是VeChainThor区块链的原生代币,具有以下功能:支付交易费用:VET币用于支付VeChainThor网络上的交易费用,包括数据存储、智能合约执行和身份验证。治理:VET币持有者可以参与VeChainThor的治理,包括对平台升级和提案进行投票。激励:VET币用于激励网络中的验证者,以确保网络的

SHIB币是什么?SHIB币的工作原理是什么? SHIB币是什么?SHIB币的工作原理是什么? Mar 17, 2024 am 08:49 AM

ShibaInu币:以狗狗为灵感的加密货币ShibaInu币(SHIB)是一种去中心化的加密货币,灵感源自于其标志性的柴犬表情包。该加密货币于2020年8月推出,旨在成为以太坊网络上的一种替代狗狗币。工作原理SHIB币是建立在以太坊区块链上的数字货币,符合ERC-20代币标准。它运用去中心化共识机制,即权益证明(PoS),这使得持有者可以通过抵押他们的SHIB代币来验证交易,并从中获得奖励。主要特点庞大的供应量:SHIB币的初始供应量为1000万亿枚,使其成为流通量最大的加密货币之一。低价格:S

Algorand币是什么?Algorand币的工作原理是什么? Algorand币是什么?Algorand币的工作原理是什么? Mar 17, 2024 am 08:30 AM

Algorand:基于纯拜占庭共识协议的区块链平台Algorand是建立在纯拜占庭共识协议之上的区块链平台,旨在提供高效、安全且可扩展的区块链解决方案。这一平台由麻省理工学院的教授SilvioMicali于2017年创立。工作原理Algorand的核心在于其独特的纯拜占庭共识协议,即Algorand共识。这个协议允许节点在不信任的环境中实现共识,即使网络中存在恶意节点。Algorand共识通过一系列步骤来实现这一目标。密钥生成:每个节点生成一对公钥和私钥。提议阶段:一个随机选择的节点提议一个新区

Beam币是什么?Beam币的工作原理是什么? Beam币是什么?Beam币的工作原理是什么? Mar 15, 2024 pm 09:50 PM

Beam币:注重隐私的加密货币Beam币是一种专注于隐私保护的加密货币,旨在提供安全且匿名的交易。它采用了MimbleWimble协议,这是一种区块链技术,通过合并交易和隐藏发送者与接收者的地址来增强用户的隐私保护。Beam币的设计理念是为用户提供一种能够确保交易信息保密的数字货币选择。通过采用这种协议,用户可以更加放心地进行交易,而无需担心他们的个人隐私信息被泄露。这种隐私保护的特性使得Beam币Beam币的工作原理MimbleWimble协议通过以下方式增强隐私:交易合并:它将多个交易组合成

AR币是什么?AR币的工作原理是什么? AR币是什么?AR币的工作原理是什么? Mar 15, 2024 pm 07:25 PM

AR币:基于增强现实技术的数字货币AR币是一种数字货币,利用增强现实技术为用户提供与数字内容互动的体验,使他们可以在现实世界中创造身临其境的体验。工作原理AR币的工作原理基于以下关键概念:增强现实(AR):AR技术将数字信息叠加在现实世界中,使用户能够与虚拟对象进行交互。区块链:区块链是一种分布式账本技术,用于记录和验证交易。它为AR币提供安全性和透明度。智能合约:智能合约是存储在区块链上的代码,用于自动化特定操作。它们在AR币的创建和管理中发挥着至关重要的作用。AR币的工作流程如下:创建AR体

See all articles