官术网_书友最值得收藏!

Working with methods

There is, however, a case you should be aware of: what happens if you are calling an object's method? If your original code had been something along the lines of:

fetch("some/remote/url").then(function(data) {
myObject.store(data);
});

Then the seemingly obvious transformed code would fail:

fetch("some/remote/url").then(myObject.store);

Why? The reason is that in the original code, the called method is bound to an object (myObject) but in the modified code, it isn't bound, and it is just a free function. We can then fix it in a simple way by using bind() as:

fetch("some/remote/url").then(myObject.store.bind(myObject));

This is a general solution. When dealing with a method, you cannot just assign it; you must use .bind( so the correct context will be available. Code like:

function doSomeMethod(someData) { 
return someObject.someMethod(someData);
}

Should be converted to:

const doSomeMethod = someObject.someMethod.bind(someObject);

Read more on .bind() at https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_objects/Function/bind.

This looks rather awkward, and not too elegant, but it's required so the method will be associated to the correct object. We will see one application of this when we promisify functions in Chapter 6Producing Functions - Higher-Order Functions. Even if this code isn't so nice to look at, whenever you have to work with objects (and, remember, we didn't say that we would be trying to aim for fully FP code and that we would accept other constructs if they made things easier) you'll have to remember to bind methods before passing them as first-class objects, in pointfree style.

主站蜘蛛池模板: 涞水县| 南涧| 休宁县| 军事| 精河县| 延庆县| 新田县| 庄浪县| 镇坪县| 丰宁| 桐乡市| 武强县| 靖边县| 双峰县| 盐城市| 商洛市| 射阳县| 绥江县| 含山县| 秦皇岛市| 肥乡县| 桐柏县| 福海县| 罗田县| 横峰县| 楚雄市| 台中市| 鸡西市| 沂南县| 平江县| 隆德县| 昌江| 贡觉县| 台东县| 巴里| 中宁县| 璧山县| 焉耆| 乳源| 兴城市| 龙口市|