JS closures - Passing a function to a child, how should the shared object be accessed
        Posted  
        
            by 
                slicedtoad
            
        on Programmers
        
        See other posts from Programmers
        
            or by slicedtoad
        
        
        
        Published on 2014-08-18T19:10:59Z
        Indexed on 
            2014/08/18
            22:31 UTC
        
        
        Read the original article
        Hit count: 375
        
I have a design and am wondering what the appropriate way to access variables is. I'll demonstrate with this example since I can't seem to describe it better than the title.
- Termis an object representing a bunch of time data (a repeating duration of time defined by a bunch of attributes)
- Termhas some print functionality but does not implement the print functions itself, rather they are passed in as anonymous functions by the parent. This would be similar to how shaders can be passed to a renderer rather than defined by the renderer.
- A container (let's call it Box) has aScheduleobject that can understand and useTermobjects.
- Boxcreates- Termobjects and passes them to- Scheduleas required.- Boxalso defines the- printfunctions stored in- Term.
- A printfunction usually takes an argument and uses it to return a string based on that argument andTerm's internal data. Sometime theprintfunction could also use data stored inSchedule, though. I'm calling this datashared.
So, the question is, what is the best way to access this shared data. I have a lot of options since JS has closures and I'm not familiar enough to know if I should be using them or avoiding them in this case.
Options:
- Create a local "reference" (term used lightly) to the - shareddata (data is not a primitive) when defining the- printfunction by accessing the- shareddata through- Schedulefrom- Box. Example:- var schedule = function(){ var sched = Schedule(); var t1 = Term( function(x){ // Term.print() return (x + sched.data).format(); }); };
- Bind it to - Termexplicitly. (Pass it in- Term's constructor or something). Or bind it in- Schedafter- Boxpasses it. And then access it as an attribute of- Term.
- Pass it in at the same time xis passed to the print function, (from sched). This is the most familiar way for my but it doesn't feel right given JS's closure ability.
- Do something weird like bindsome context and arguments toprint.
I'm hoping the correct answer isn't purely subjective. If it is, then I guess the answer is just "do whatever works". But I feel like there are some significant differences between the approaches that could have a large impact when stretched beyond my small example.
© Programmers or respective owner