Maison interface Web uni-app uniapp ajoute dynamiquement des vues

uniapp ajoute dynamiquement des vues

May 26, 2023 am 09:23 AM

Ces dernières années, avec la popularité des applications mobiles, les développeurs ont une demande croissante de création rapide d'applications mobiles. Dans le développement d'applications mobiles, UniApp, en tant que cadre de développement mobile multiplateforme, est privilégié par de plus en plus de développeurs. L'un des avantages d'UniApp est qu'il possède une bonne expérience de développement et une riche bibliothèque de composants. Il peut non seulement créer rapidement des pages de base, mais également implémenter une logique interactive complexe.

Cet article présentera comment UniApp peut augmenter et ajouter dynamiquement des vues pour répondre aux besoins de mise en œuvre d'une logique d'interaction complexe.

Tout d'abord, nous devons clarifier le concept de base d'UniApp. Dans UniApp, une page est composée de plusieurs composants. Chaque composant peut représenter une vue ou un comportement. Différents composants peuvent être imbriqués et combinés les uns avec les autres pour former diverses pages complexes.

Ensuite, voyons comment ajouter des composants de manière dynamique. Prenons comme exemple une exigence simple : sur une page, cliquez sur un bouton pour ajouter dynamiquement une zone de texte.

Tout d'abord, définissez un composant de bouton sur la page. Lorsque vous cliquez sur le bouton, ajoutez une zone de texte. Le code spécifique est le suivant :

<template>
  <view>
    <button @tap="addInput">添加文本框</button>
    <view class="input-container">
      <!-- 这里是我们要添加的文本框 -->
    </view>
  </view>
</template>

<script>
export default {
  methods: {
    addInput() {
      // 动态添加文本框的操作
    }
  }
}
</script>
Copier après la connexion

Dans la méthode addInput de l'événement click du bouton, nous devons ajouter dynamiquement un composant de zone de texte. UniApp fournit une méthode de composants dynamiques, qui peut être implémentée via des composants de composants. Le code spécifique est le suivant :

<template>
  <view>
    <button @tap="addInput">添加文本框</button>
    <view class="input-container">
      <!-- 这里是我们要添加的文本框 -->
      <component :is="inputComponent"></component>
    </view>
  </view>
</template>

<script>
export default {
  data() {
    return {
      inputComponent: 'input'
      // 这里我们先设置为原生的input组件,后面会解释如何动态改变组件类型
    }
  },
  methods: {
    addInput() {
      // 动态添加文本框的操作
      this.inputComponent = 'input' // 这里我们先设置为原生的input组件
    }
  }
}
</script>
Copier après la connexion

Dans le code ci-dessus, nous lions dynamiquement un composant via inputComponent et indiquons au composant le type de composant à restituer via la directive :is.

Maintenant, nous devons mettre en œuvre l'opération d'ajout dynamique de zones de texte. Le code spécifique est le suivant :

<template>
  <view>
    <button @tap="addInput">添加文本框</button>
    <view class="input-container">
      <!-- 这里是我们要添加的文本框 -->
      <component :is="inputComponent"></component>
    </view>
  </view>
</template>

<script>
export default {
  data() {
    return {
      inputComponent: 'input'
      // 这里我们先设置为原生的input组件,后面会解释如何动态改变组件类型
    }
  },
  methods: {
    addInput() {
      // 动态添加文本框的操作
      this.inputComponent = 'input' // 这里我们先设置为原生的input组件
      
      // 使用uni.$createComponent创建一个新的组件实例
      const inputInstance = uni.$createComponent({
        // 组件的选择器
        selector: 'dynamic-input',
        // 组件的模板
        template: '<input v-model="value" placeholder="请输入内容"></input>',
        // 组件的数据
        data() {
          return {
            value: ''
          }
        }
      })
      
      // 使用this.$refs获取到容器内的dom对象
      const containerDom = this.$refs.inputContainer.$el
      
      // 使用uni.$app.$mount将组件实例挂载到dom容器中
      inputInstance.$mount(containerDom)
    }
  }
}
</script>
Copier après la connexion

Dans le code ci-dessus, nous utilisons d'abord la méthode uni.$createComponent pour créer une nouvelle instance de composant dynamique, puis utilisons this.$refs pour obtenir l'objet DOM de le conteneur, puis utilisez uni. La méthode $app.$mount monte l'instance du composant dans le conteneur dom.

Maintenant, nous pouvons exécuter le code, cliquer sur le bouton et ajouter avec succès une zone de texte de manière dynamique. Cependant, si nous souhaitons modifier dynamiquement le type de composant, par exemple en ajoutant un bouton radio, nous devons modifier dynamiquement la valeur de inputComponent, puis réexécuter l'opération d'ajout dynamique du composant.

Cet article explique comment augmenter et ajouter dynamiquement des vues dans UniApp en créant dynamiquement des instances de composants, et explique comment modifier dynamiquement les types de composants. J'espère que cet article pourra être utile aux développeurs mobiles.

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment gérer le stockage local à Uni-App? Comment gérer le stockage local à Uni-App? Mar 11, 2025 pm 07:12 PM

Cet article détaille les API de stockage local d'Uni-App (Uni.SetStorageSync (), Uni.GetStoragesYnc (), et leurs homologues asynchrones), mettant l'accent sur les meilleures pratiques telles que l'utilisation de clés descriptives, la limitation de la taille des données et la gestion de l'analyse JSON. Ça souligne que lo

Comment gérer l'état à Uni-App à l'aide de Vuex ou PINIA? Comment gérer l'état à Uni-App à l'aide de Vuex ou PINIA? Mar 11, 2025 pm 07:08 PM

Cet article compare Vuex et PINIA pour la gestion de l'État à Uni-App. Il détaille leurs fonctionnalités, leur implémentation et leurs meilleures pratiques, mettant en évidence la simplicité de Pinia contre la structure de Vuex. Le choix dépend de la complexité du projet, avec Pinia Suita

Comment faire des demandes d'API et gérer les données dans Uni-App? Comment faire des demandes d'API et gérer les données dans Uni-App? Mar 11, 2025 pm 07:09 PM

Cet article détaille la fabrication et la sécurisation des demandes d'API dans Uni-App à l'aide de Uni.Request ou Axios. Il couvre la gestion des réponses JSON, les meilleures pratiques de sécurité (HTTPS, authentification, validation des entrées), dépannage des échecs (problèmes de réseau, CORS, S

Comment utiliser les API de géolocalisation Uni-App? Comment utiliser les API de géolocalisation Uni-App? Mar 11, 2025 pm 07:14 PM

Cet article détaille les API de géolocalisation d'Uni-App, en se concentrant sur Uni.getLocation (). Il traite des pièges communs comme des systèmes de coordonnées incorrects (GCJ02 vs WGS84) et des problèmes d'autorisation. Améliorer la précision de l'emplacement via des lectures en moyenne et une manipulation

Comment utiliser les API de partage social de l'Uni-App? Comment utiliser les API de partage social de l'Uni-App? Mar 13, 2025 pm 06:30 PM

L'article détaille comment intégrer le partage social dans les projets Uni-App à l'aide de l'API Uni.share, couvrant la configuration, la configuration et les tests sur des plateformes comme WeChat et Weibo.

Comment utiliser la fonction Easycom d'Uni-App pour l'enregistrement des composants automatiques? Comment utiliser la fonction Easycom d'Uni-App pour l'enregistrement des composants automatiques? Mar 11, 2025 pm 07:11 PM

Cet article explique la fonctionnalité Easycom d'Uni-App, l'automatisation de l'enregistrement des composants. Il détaille la configuration, y compris Autoscan et la cartographie des composants personnalisés, mettant en évidence des avantages tels que la binelle réduite, la vitesse améliorée et la lisibilité améliorée.

Comment utiliser des préprocesseurs (Sass, moins) avec Uni-App? Comment utiliser des préprocesseurs (Sass, moins) avec Uni-App? Mar 18, 2025 pm 12:20 PM

L'article discute de l'utilisation de SASS et moins de préprocesseurs dans UNI-APP, de la configuration de détail, des avantages sociaux et de la double utilisation. L'accent principal est sur la configuration et les avantages. [159 caractères]

Comment utiliser l'API UNI.Request Uni-App pour faire des demandes HTTP? Comment utiliser l'API UNI.Request Uni-App pour faire des demandes HTTP? Mar 11, 2025 pm 07:13 PM

Cet article détaille l'API UNI.Request dans Uni-App pour faire des demandes HTTP. Il couvre l'utilisation de base, les options avancées (méthodes, en-têtes, types de données), techniques de traitement des erreurs robustes (rappels d'échec, vérification du code d'état) et intégration avec Authenticat

See all articles