javascript - js 这个aop里的 this 劫持 什么意思

查看:89
本文介绍了javascript - js 这个aop里的 this 劫持 什么意思的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题


这里的 beforefn.apply(this,arguments); this 改为 window或null可以吗?

function a() {
console.log('self');
}


var obj = {
name:'li',
getName: function() {
    console.log(this.name);
}
}


Function.prototype.before = function(beforeFn) {
var __self = this;
return function() {
    beforeFn.apply(this,arguments);
    __self.apply(this,arguments)
}
}


var b = a.before(obj.getName);
b();

如果我想 通过a.before执行obj.getName 得到 'li' 这个值,如何处理这套程序?现在这套before程序执行结果,无法获得obj.name的值

解决方案

不行,this需要根据执行的宿主确定,有可能是windows,也有可能是某个对象。

var funcA = function() {
  console.log('a');
};
var funB = function() {
  console.log(this.b)
};
var b = '我是window中的b';
var objB = {b: '我是objB中的b'};
var test1 = funcA.before(funB);
test1(); // 输出`我是window中的b`, 因为这个时候this指向的是windows
objB.test1 = test1;
objB.test1(); // 输出`我是objB中的b`, 因为这个时候this指向的是objB

如果按照你说的将this改为window,那么this将永远指向windowobjB.test1()得到的结果将是我是window中的bthis就被劫持了。


后面的需求,动态设置this指向

var b = a.before(obj.getName).bind(obj);
b(); 

这篇关于javascript - js 这个aop里的 this 劫持 什么意思的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆