[removed] global scope

前端 未结 4 644
一个人的身影
一个人的身影 2021-02-03 12:15

Nowdays, i create a .js file with a lot of functions and then I link it to my html pages. That\'s working but I want to know what\'s the best way (good practices) to insert js i

相关标签:
4条回答
  • 2021-02-03 12:51

    A simple idea is to use one object that represents your namespace:

    var NameSpace = {
        Person : function(name, age) {
    
        }
    };
    
    var jim= new NameSpace.Person("Jim", 30);
    
    0 讨论(0)
  • 2021-02-03 12:55

    The best way is to create a new scope and execute your code there.

    (function(){
      //code here
    })();
    

    This is best used when the global scope is accessed at a minimum.

    Basically, this defines an anonymous function, gives it a new scope, and calls it.

    0 讨论(0)
  • 2021-02-03 12:56

    You could wrap them in an anonymous function like:

    (function(){ /* */ })();

    However, if you need to re-use all of the javascript functions you've written elsewhere (in other scripts), you're better off creating a single global object on which they can be accessed. Either like:

    var mySingleGlobalObject={};
    mySingleGlobalObject.someVariable='a string value';
    mySingleGlobalObject.someMethod=function(par1, par2){ /* */ };
    

    or the alternative, shorter syntax (which does the same thing):

    var mySingleGlobalObject={
      someVariable:'a string value',
      someMethod:function(par1, par2){ /* */ }
    };

    This can then be accessed later from other scripts like:

    mySingleGlobalObject.someMethod('jack', 'jill');
    0 讨论(0)
  • 2021-02-03 13:01

    It's perhaps not the BEST way, but a lot of PHP systems (I'm looking at you, Drupal) take the name of their particular plugin and prepend it to all their function names. You could do something similar, adding the name of your capability to your function names - "mything_do_action()"

    Alternately, you could take a more "OO" approach, and create an object that encapsulates your capability, and add all your functions as member functions on IT. That way, there's only one thing in global scope to worry about.

    0 讨论(0)
提交回复
热议问题