Self-references in object literals/initializers
P粉921130067
P粉921130067 2023-08-29 12:38:19
0
2
482
<p>Is there any way to make something like the following work in JavaScript? </p> <pre class="brush:php;toolbar:false;">var foo = { a: 5, b: 6, c: this.a this.b // Doesn't work };</pre> <p>In its current form, this code obviously throws a reference error because <code>this</code> does not reference <code>foo</code>. But<em>yes</em>Is there any way to make the value in an object literal property dependent on other previously declared properties? </p>
P粉921130067
P粉921130067

reply all(2)
P粉615829742

You can do this:

var foo = {
   a: 5,
   b: 6,
   init: function() {
       this.c = this.a + this.b;
       return this;
   }
}.init();

This will be some kind of one-time initialization of the object.

Note that you are actually assigning the return value of init() to foo, so you must return that value .

Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template