javascript - Si une méthode doit utiliser des données externes, devriez-vous choisir de la transmettre en tant que paramètre ou de sauvegarder les données en tant que variable globale par rapport à la portée actuelle ~
女神的闺蜜爱上我
女神的闺蜜爱上我 2017-07-05 11:00:45
0
3
865
var test = {
    init: function () {
        var data = $rootScope.test;
        
        if(data) {
            ……
            this.method(data);
        } 
    },
    
    method: function (data) {
        console.log(data);
    }
};

toujours

var test = {
    data: $rootScope.test,
    
    init: function () {
        if(this.data) {
            ……
            this.method();
        } 
    },
    
    method: function () {
        console.log(this.data);
    }
};

Quelle méthode est la meilleure pratique

Que faire s'il y a trop de niveaux à passer dans la première méthode. Par exemple, il commence par init et appelle la méthode après l'avoir passée, il y a [n] méthodes. -> méthode2 -> méthode3. Cela nécessite un passage au premier niveau...

Il existe également deux méthodes, laquelle est la plus performante ? La deuxième méthode équivaut à obtenir les propriétés de l'objet à chaque fois. Il semble que les performances du passage direct des paramètres seront moins bonnes ? ~

女神的闺蜜爱上我
女神的闺蜜爱上我

répondre à tous(3)
三叔

Transfer, utilisez moins souvent les variables globales

淡淡烟草味

Les variables globales ne sont pas comptées dans votre exemple !

Accrochez-vous aux propriétés de l'objet et n'affectera pas l'utilisation des variables à l'intérieur de la méthode ! Cela ne polluera pas non plus le scope !

曾经蜡笔没有小新

Ce que vous avez implémenté ici n'est pas une variable globale, elle est simplement attachée aux propriétés de l'objet. Pourquoi est-il nécessaire de déclarer une variable ici Je ne vous ai pas vu réellement opérer celadata,如果只是想引用一下值得话,那么直接用$rootScope.testN'est-ce pas génial ?

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal