Javascript function wrapping
05 April 2017
DESCRIPTION: Making functions globally available becomes extremely confusing as your project builds in scale. Wrapping functions is a tidy solution to control accessibility to your functions. This blog will tackle this topic.
Introduction
If you only just started writing JavaScript you will realise that initially it appears relatively easy to write and access your functions when they are globally available:
function testingFunction() {
console.log("This is a test")
}
As your project scales however and you get more and more functions, you will realise that it can get extremely confusing having to uniquely name each of your functions, and where they are located.
Binding this
When calling a function you can pass an argument to be called within the function. The call()
method can be used to call a function with a given this
value and arguments provided individually.
function testingMessage(message) {
console.log(`${this} ${message}`)
}
testingMessage.call("hello", "Sam") // => "hello Sam"
We can also bind the value of this
rather than individually setting the value of this in call()
, by running this:
function testingMessage(message) {
console.log(`${this} ${message}`)
}
let bindingTestingMessage = testingMessage.bind('Action', 'Sam');
bindingTestingMessage(); // => 'Action Sam'
Even if you try calling bindingTestingMessage.call("Test")
it will not change the value of this
, and would therefore return "Action Sam"
rather than "Test Sam"
.
Closure
Closures can be used to permanently change the value of this
without using bind
.
let name = "Sam"
let bindingMyName = function() {
myName.call(name)
}
bindingMyName() // => "Sam"
bindingMyName.call("Bill") // => "Sam" - cannot override `this`