Maison > interface Web > uni-app > Comment définir des variables globalement dans Uniapp

Comment définir des variables globalement dans Uniapp

coldplay.xixi
Libérer: 2023-01-13 00:44:08
original
10230 Les gens l'ont consulté

Comment uniapp définit les variables globales : 1. Utilisez un module public, le code est [return obj instanceof Array] 2. Étendez directement certaines constantes ou méthodes fréquemment utilisées à [Vue.prototype] ;

Comment définir des variables globalement dans Uniapp

L'environnement d'exploitation de ce tutoriel : système windows7, version uni-app2.5.1, ordinateur Dell G3. Cette méthode convient à toutes les marques d'ordinateurs.

Recommandé (gratuit) : Tutoriel de développement uni-app

Comment définir des variables globales dans uniapp :

1. Le module public

définit un module dédié pour organiser et gérer ces variables globales et les introduire sur les pages requises.

Notez que cette méthode ne prend en charge que le partage entre plusieurs pages vue ou plusieurs pages nvue, mais pas entre vue et nvue.

L'exemple est le suivant :

Créez un répertoire commun dans le répertoire racine du projet uni-app, puis créez un nouveau helper.js dans le répertoire commun pour définir les méthodes publiques.

const websiteUrl = 'http://uniapp.dcloud.io';  
const now = Date.now || function () {  
    return new Date().getTime();  
};  
const isArray = Array.isArray || function (obj) {  
    return obj instanceof Array;  
};  
export default {  
    websiteUrl,  
    now,  
    isArray  
}
Copier après la connexion

Ensuite, référencez le module dans pages/index/index.vue

<script>  
    import helper from &#39;../../common/helper.js&#39;;  
    export default {  
        data() {  
            return {};  
        },  
        onLoad(){  
            console.log(&#39;now:&#39; + helper.now());  
        },  
        methods: {  
        }  
    }  
</script>
Copier après la connexion

Cette méthode est plus pratique à maintenir, mais l'inconvénient est qu'elle doit être introduite à chaque fois.

2. Montez Vue.prototype

Étendez certaines constantes ou méthodes fréquemment utilisées directement à Vue.prototype, et chaque objet Vue "" héritera ".

Notez que cette méthode ne prend en charge que les pages vue

L'exemple est le suivant :

Monter les propriétés/méthodes dans main.js

Vue.prototype.websiteUrl = &#39;http://uniapp.dcloud.io&#39;;  
Vue.prototype.now = Date.now || function () {  
    return new Date().getTime();  
};  
Vue.prototype.isArray = Array.isArray || function (obj) {  
    return obj instanceof Array;  
};
Copier après la connexion

Puis dans les pages / Cette méthode d'appel de

<script>  
    export default {  
        data() {  
            return {};  
        },  
        onLoad(){  
            console.log(&#39;now:&#39; + this.now());  
        },  
        methods: {  
        }  
    }  
</script>
Copier après la connexion

dans index/index.vue n'a besoin d'être définie que dans main.js et peut être appelée directement dans chaque page.

Conseils

  • Ne pas avoir de noms d'attributs ou de méthodes en double dans chaque page.

  • Il est recommandé que les attributs ou méthodes montés sur Vue.prototype puissent être ajoutés avec un préfixe unifié. Par exemple, $url et global_url sont faciles à distinguer du contenu de la page actuelle lors de la lecture du code.

3. globalData

Il existe un concept de globalData dans l'applet, et des variables globales peuvent être déclarées sur l'application. Vue n'avait pas ce genre de concept auparavant, mais uni-app a introduit le concept globalData et l'a implémenté sur des plates-formes telles que H5 et App.

Vous pouvez définir globalData dans App.vue, ou vous pouvez utiliser l'API pour lire et écrire cette valeur.

  • globalData prend en charge le partage de données vue et nvue.

  • globalData est un moyen relativement simple d'utiliser des variables globales.

Définition : App.vue

<script>  
    export default {  
        globalData: {  
            text: &#39;text&#39;  
        },  
        onLaunch: function() {  
            console.log(&#39;App Launch&#39;)  
        },  
        onShow: function() {  
            console.log(&#39;App Show&#39;)  
        },  
        onHide: function() {  
            console.log(&#39;App Hide&#39;)  
        }  
    }  
</script>  
<style>  
    /*每个页面公共css */  
</style>
Copier après la connexion


La façon d'exploiter globalData en js est la suivante :

  • Affectation : getApp().globalData.text = &#39;test&#39;

  • Valeur : console.log(getApp().globalData.text) // &#39;test&#39;

Si vous devez lier les données globalData au page, les variables peuvent être réaffectées dans le cycle de déclaration onshow de la page. À partir de HBuilderX 2.0.3, les pages nvue prennent également en charge onshow en mode compilation uni-app.

4. Vuex

Vuex est un modèle de gestion d'état développé spécifiquement pour les applications Vue.js. Il utilise un stockage centralisé pour gérer l'état de tous les composants de l'application et utilise les règles correspondantes pour garantir que l'état change de manière prévisible.

Voici un exemple de mise à jour synchrone des informations utilisateur après la connexion pour expliquer brièvement l'utilisation de Vuex. Pour un contenu Vuex plus détaillé, il est recommandé d'aller sur son site officiel Vuex pour en savoir plus.

Exemple :

Créez un nouveau répertoire de magasin dans le répertoire racine du projet uni-app, créez index.js dans le répertoire du magasin pour définir la valeur d'état

const store = new Vuex.Store({  
    state: {  
        login: false,  
        token: &#39;&#39;,  
        avatarUrl: &#39;&#39;,  
        userName: &#39;&#39;  
    },  
    mutations: {  
        login(state, provider) {  
            console.log(state)  
            console.log(provider)  
            state.login = true;  
            state.token = provider.token;  
            state.userName = provider.userName;  
            state.avatarUrl = provider.avatarUrl;  
        },  
        logout(state) {  
            state.login = false;  
            state.token = &#39;&#39;;  
            state.userName = &#39;&#39;;  
            state.avatarUrl = &#39;&#39;;  
        }  
    }  
})
Copier après la connexion

Ensuite, vous devez créer un nouveau répertoire de magasin dans le répertoire principal. .js mount Vuex

import store from &#39;./store&#39;  
Vue.prototype.$store = store
Copier après la connexion

Enfin, utilisez

<script>  
    import {  
        mapState,  
        mapMutations  
    } from &#39;vuex&#39;;  
    export default {  
        computed: {  
            ...mapState([&#39;avatarUrl&#39;, &#39;login&#39;, &#39;userName&#39;])  
        },  
        methods: {  
            ...mapMutations([&#39;logout&#39;])  
        }  
    }  
</script>
Copier après la connexion

dans pages/index/index.vue Apprentissage gratuit associé. recommandations : Vidéo de programmation

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal