I need to know what I am doing wrong because I cannot call the internal functions show or hide?
(function()
{
var Fresh = {
notify:function()
{
var timeout = 20000;
$("#notify-container div").get(0).id.substr(7,1) == "1" && (show(),setTimeout(hide(),timeout));
var show = function ()
{
$("body").animate({marginTop: "2.5em"}, "fast", "linear");
$("#notify-container div:eq(0)").fadeIn("slow");
},
hide = function()
{
$("#notify-container div").hide();
}
}//END notify
}
window.Fresh = Fresh;
})();
Fresh.notify();
thanks, Richard
UPDATE
If you wanted to be able to do something like:
Fresh.notify.showMessage(), all you need to do is assign a property to the functionnotify:This will point to the function object here, and can be called as such (
this()===Fresh.notify();). That’s all there is too it.There’s a number of issues with this code. First of all: it’s great that you’re trying to use closures. But you’re not using them to the fullest, if you don’t mind my saying. For example: the
notifymethod is packed with function declarations and jQuery selectors. This means that each time the method is invoked, new function objects will be created and the selectors will cause the dom to be searched time and time again. It’s better to just keep the functions and the dom elements referenced in the closure scope:It’s hard to make suggestions in this case, though because, on its own, this code doesn’t really make much sense. I’d suggest you set up a fiddle so we can see the code at work (or see the code fail :P)