Table des matières
1. Slots
二、父子组件通讯
Maison Applet WeChat Développement de mini-programmes Une brève analyse de plusieurs façons de communiquer entre les slots et les composants parent-enfant dans les mini-programmes

Une brève analyse de plusieurs façons de communiquer entre les slots et les composants parent-enfant dans les mini-programmes

Nov 02, 2021 am 09:57 AM
小程序 微信 插槽 父子组件通讯

Cet article vous présentera les emplacements de l'applet WeChat et plusieurs méthodes de communication entre les composants parent-enfant. J'espère qu'il vous sera utile !

Une brève analyse de plusieurs façons de communiquer entre les slots et les composants parent-enfant dans les mini-programmes

Aujourd'hui, nous allons examiner la communication entre les slots et les composants parent-enfant dans le mini programme, et voir quelles sont les différences avec vue ? [Recommandations d'apprentissage associées : Tutoriel de développement de mini-programmes]

1. Slots

1.

Dans la structure wxml d'un composant personnalisé, un nœud (slot) peut être fourni pour héberger la structure wxml fournie par l'utilisateur du composantwxml 结构中,可以提供一个 节点(插槽),用于承载组件使用者提供的 wxml 结构

Une brève analyse de plusieurs façons de communiquer entre les slots et les composants parent-enfant dans les mini-programmes

其实插槽, 说的通俗一些, 就是 子组件挖坑,父组件填坑 的过程。由父组件在使用子组件的时候, 决定子组件内部的某一些布局展示

  • 子组件通过挖坑
  • 父组件通过组件标签中间的内容来填坑

2. 单个插槽

在小程序中,默认每个自定义组件中只允许使用一个  slot 占位,这种个数上的限制叫做单个插槽

  • 默认情况下,一个组件的 wxml 中只能有一个 slot
  • 需要使用多 slot 时,可以在组件 js 中声明启用
  • 注意:小程序中目前只有默认插槽和多个插槽,暂不支持作用域插槽

代码如下(示例):

<!-- 组件的封装者 -->
<view class="wrapper">
  <view>这里是组件的内部节点</view>
  <!-- 对于不确定的内容,可以使用<slot>进行占位,具体的内容由组件的使用者决定 -->
  <slot></slot>
</view>

<!-- 组件的使用者 -->
<component-tag-name>
  <!-- 这部分内容将被放置在组件<slot>的位置上 -->
  <view>这里是插入到组件slot的内容</view>
</component-tag-name>
Copier après la connexion

3. 启动多个插槽

在小程序的自定义组件中,需要使用多 插槽时,可以在组件的 .js 文件中

代码如下(示例):

Component({
  options: {
    multipleSlots: true // 在组件定义时的选项中启用多 slot 支持
  },
  properties: { /* ... */ },
  methods: { /* ... */ }
})
Copier après la connexion

4. 定义多个插槽

可以在组件的 .wxml 中使用多个 标签,以不同的 name 来区分不同的插槽

代码如下(示例):

<!-- 组件模板 -->
<view class="wrapper">
  <!-- name 为 before 的第一个 slot 插槽 -->
  <slot name="before"></slot>
  <view>这是一段固定的文本内容</view>
  <!-- name 为 after 的第二个 slot 插槽 -->
  <slot name="after"></slot>
</view>
Copier après la connexion

二、父子组件通讯

1. 父子组件通讯方式

  • 属性绑定 用于父组件向子组件的指定属性设置数据,仅能设置 JSON 兼容的数据(只能传递数据,不能传递方法)

  • 事件绑定 用于子组件向父组件传递数据,可以传递任意数据(包括数组和方法)

  • 获取组件实例 父组件还可以通过 this.selectComponent() 获取子组件实例对象这样就可以直接访问子组件的任意数据和方法

2. 属性绑定

  • 传递数据 属性绑定用于实现父向子传值,而且只能传递普通类型的数据,无法将方法传递给子组件

代码如下(示例):

// 父组件的 data 节点
data: {
  count: 0
}

// 父组件的wxml 结构
<my-test3 count="{{count}}"></my-test3>
<view>~~</view>
<view>父组件中,count值为:{{count}}</view>
Copier après la connexion
  • 接受数据

子组件在 properties 节点中声明对应的属性并使用 代码如下(示例):

// 子组件的 properties 节点
properties: {
  count: Number
}

// 子组件的 wxml 结构
<text>子组件中,count值为:{{count}}</text>
Copier après la connexion

3. 事件绑定的核心实现步骤

事件绑定用于实现子向父传值,可以传递任何类型的数据。使用步骤如下:

  • 父组件js 中,定义一个函数,这个函数即将通过自定义事件的形式,传递给子组件
  • 父组件wxml 中,通过自定义事件的形式,将步骤 1 中定义的函数引用,传递给子组件
  • 子组件js 中,通过调用 this.triggerEvent(&#39;自定义事件名称&#39;, {/* 参数对象 */}),将数据发送到父组件
  • 在父组件的 js 中,通过 e.detail 获取到子组件传递过来的数据

4. 事件绑定的核心实现代码

  • 步骤1: 在父组件的 js 中,定义一个函数,这个函数即将通过自定义事件的形式,传递给子组件

代码如下(示例):

// 父组件中定义 syncCount 方法
// 将来,这个方法会被传递给子组件,供子组件进行调用
syncCount() {
  console.log(&#39;syncCount&#39;)
},
Copier après la connexion
  • 步骤 2:在父组件的 wxml 中,通过自定义事件的形式,将 步骤 1 中定义的函数引用,传递给子组件

代码如下(示例):

<!-- 使用 bind: 自定义事件名称(推荐:结构清晰) -->
<my-test3 count="{{count}}" bind:sync="syncCount"></my-test3>
<!-- 或在 bind 后面直接协商自定义事件名称 -->
<my-test3 count="{{count}}" bindsync="syncCount"></my-test3>
Copier après la connexion
  • 步骤 3:在 子组件js 中,通过调用 this.triggerEvent(&#39;自定义事件名称&#39;, {/* 参数对象 */})
  • Une brève analyse de plusieurs façons de communiquer entre les slots et les composants parent-enfant dans les mini-programmes

en fait, dit Le plus La version populaire est le processus par lequel les composants enfants creusent des trous et les composants parents remplissent les trous. Lorsque le composant parent utilise le composant enfant, il détermine une certaine disposition d'affichage à l'intérieur du composant enfant

  • Le composant enfant creuse des trous🎜
  • Le composant parent remplit le trou à travers le contenu au milieu de la balise du composant. 🎜🎜🎜🎜 🎜2. Emplacement unique🎜🎜🎜🎜Dans le mini programme, par défaut, un seul espace réservé slot est autorisé dans chaque composant personnalisé. Cette limite du nombre est appelée un seul emplacement🎜<. ul>
  • Par défaut, il ne peut y avoir qu'un seul slot dans le wxml d'un composant🎜
  • Lorsque vous devez utiliser plusieurs slot , Il peut être déclaré activé dans le composant js 🎜
  • 🎜Remarque🎜 : Il n'y a actuellement que des emplacements par défaut et plusieurs emplacements dans l'applet, et les emplacements de portée ne sont pas encore pris en charge 🎜🎜🎜Le code est la suivante (exemple ): 🎜
    // 子组件的wxml结构
    <text>子组件中,count值为:{{count}}</text>
    <button type="primary" bindtap="addCount">+1</button>
    
    // 子组件中的 js 代码
    methods: {
      addCount() {
        this.setData({
          count: this.properties.count + 1
        })
        this.triggerEvent(&#39;sync&#39;, {value: this.properties.count})
      }
    }
    Copier après la connexion
    Copier après la connexion
    🎜🎜🎜3. Démarrez plusieurs slots🎜🎜🎜🎜Dans le composant personnalisé du mini programme, lorsque vous devez utiliser plusieurs slots, vous pouvez dans le .js</code > fichier du composant🎜 🎜Le code est le suivant (exemple) :🎜<div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>syncCount(e) { // console.log(e.detail.value) this.setData({ count: e.detail.value }) }</pre><div class="contentsignin">Copier après la connexion</div></div><div class="contentsignin">Copier après la connexion</div></div>🎜🎜🎜4 Définissez plusieurs slots🎜🎜🎜🎜Vous pouvez utiliser plusieurs balises dans le <code>.wxml du composant avec différents <. code>nom< /code> pour distinguer les différents emplacements🎜🎜Le code est le suivant (exemple) :🎜
    // wxml结构
    <my-test3 count="{{count}}" bind:sync="syncCount" class="customA" id="cA"></my-test3>
    <button bindtap="getChild">获取子组件实例</button>
    
    getChild() { // 按钮的tap事件处理函数
      // 切记下面参数不能传递标签选择器 &#39;my-test3&#39;,不然返回的是 null
      const child = this.selectComponent(&#39;.customA&#39;) // 也可以传递 id 选择器 #cA
      child.setData({ count: child.properties.count + 1 }) // 调用子组件的 setData 方法
      child.addCount() // 调用子组件的 addCount 方法 
    }
    Copier après la connexion
    Copier après la connexion
    🎜🎜2. Communication des composants parent-enfant🎜🎜🎜🎜🎜1. ul>
  • 🎜Liaison d'attribut Utilisé pour les composants parents pour définir les données sur les propriétés spécifiées des composants enfants. Seules les données compatibles JSON peuvent être définies (seules les données peuvent être transmises, les méthodes ne peuvent pas être transmises)🎜🎜
  • 🎜Liaison d'événement. Utilisé pour que les composants enfants transmettent des données aux composants parents. Toutes les données (y compris les tableaux et les méthodes) peuvent être transmises🎜🎜
  • 🎜Obtenir l'instance du composant. Le composant parent peut également obtenir l'objet instance du composant enfant via this.selectComponent(), afin qu'il puisse accéder directement à toutes les données et méthodes du composant enfant🎜🎜🎜🎜🎜🎜2. 🎜🎜
    • Transférer des données La liaison de propriété est utilisée pour transférer des valeurs du parent à l'enfant et ne peut transmettre que des types de données ordinaires. Les méthodes ne peuvent pas être transmises aux composants enfants. Le code est le suivant (exemple) : 🎜rrreee
      • . Acceptez les données🎜🎜🎜 Les sous-composants déclarent les propriétés correspondantes dans le nœud de propriétés et utilisent Le code est le suivant (exemple) : 🎜rrreee🎜🎜🎜3. Les principales étapes de mise en œuvre de la liaison d'événement🎜🎜🎜🎜La liaison d'événement est utilisée pour transférer des valeurs de l'enfant au parent, et tout type de données peut être passé. Les étapes sont les suivantes : 🎜
        • Dans composant parent, définissez une fonction en js. Cette fonction sera passée au composant enfant sous la forme de. un événement personnalisé. 🎜
        • Dans wxml du composant parent, transmettez la référence de fonction définie à l'étape 1 au composant enfant sous la forme d'un événement personnalisé🎜
        • Dans Dans js du sous-composant, en appelant this.triggerEvent('custom event name', {/*setting object*/}), Envoyer des données au composant parent🎜
        • Dans le js du composant parent, obtenez les données transmises par le composant enfant via e.detail🎜🎜🎜🎜🎜4 . Le code d'implémentation principal de la liaison d'événement🎜🎜🎜
          • Étape 1 : Dans le js du composant parent, définissez une fonction qui sera transmise à l'enfant sous la forme de. un événement personnalisé Le code du composant 🎜🎜🎜 est le suivant (exemple) : 🎜rrreee
            • Etape 2 : Dans le wxml du composant parent, référencez la fonction définie à l'étape 1 sous la forme d'un événement personnalisé, passé au sous-composant 🎜🎜🎜Le code est le suivant (exemple) : 🎜rrreee
              • Étape 3 : Dans js de sous-composant, en appelant this.triggerEvent('custom event name', {/*setting object*/}), envoyez les données au composant parent🎜🎜🎜Le code est comme suit (exemple) :🎜
                // 子组件的wxml结构
                <text>子组件中,count值为:{{count}}</text>
                <button type="primary" bindtap="addCount">+1</button>
                
                // 子组件中的 js 代码
                methods: {
                  addCount() {
                    this.setData({
                      count: this.properties.count + 1
                    })
                    this.triggerEvent(&#39;sync&#39;, {value: this.properties.count})
                  }
                }
                Copier après la connexion
                Copier après la connexion
                • 步骤 4:在父组件的 js 中,通过 e.detail 获取到子组件传递过来的数据

                代码如下(示例):

                syncCount(e) {
                  // console.log(e.detail.value)
                  this.setData({
                    count: e.detail.value
                  })
                }
                Copier après la connexion
                Copier après la connexion

                5. 使用 selectComponent 获取组件实例

                父组件如何获得子组件实例?

                可在父组件里调用 this.selectComponent("id或class选择器"),获取子组件的实例对象,从而直接访问子组件的任意数据和方法。调用时需要传入一个选择器,例如 this.selectComponent(".my-component")

                代码如下(示例):

                // wxml结构
                <my-test3 count="{{count}}" bind:sync="syncCount" class="customA" id="cA"></my-test3>
                <button bindtap="getChild">获取子组件实例</button>
                
                getChild() { // 按钮的tap事件处理函数
                  // 切记下面参数不能传递标签选择器 &#39;my-test3&#39;,不然返回的是 null
                  const child = this.selectComponent(&#39;.customA&#39;) // 也可以传递 id 选择器 #cA
                  child.setData({ count: child.properties.count + 1 }) // 调用子组件的 setData 方法
                  child.addCount() // 调用子组件的 addCount 方法 
                }
                Copier après la connexion
                Copier après la connexion

                更多编程相关知识,请访问:编程入门!!

                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 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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)

Il y a des rumeurs selon lesquelles 'l'iPhone 16 pourrait ne pas prendre en charge WeChat', et le consultant technique d'Apple en Chine a déclaré qu'il communiquait avec Tencent au sujet des commissions de l'App Store. Il y a des rumeurs selon lesquelles 'l'iPhone 16 pourrait ne pas prendre en charge WeChat', et le consultant technique d'Apple en Chine a déclaré qu'il communiquait avec Tencent au sujet des commissions de l'App Store. Sep 02, 2024 pm 10:45 PM

Merci aux internautes Qing Qiechensi, HH_KK, Satomi Ishihara et Wu Yanzu du sud de la Chine pour avoir soumis des indices ! Selon les informations du 2 septembre, il y a eu des rumeurs récentes selon lesquelles "l'iPhone 16 pourrait ne pas prendre en charge WeChat". En réponse, un journaliste de Shell Finance a appelé la hotline officielle d'Apple en Chine pour savoir si les systèmes iOS ou les appareils Apple pouvaient continuer à le faire. utilisez WeChat et WeChat La question de savoir s'il peut continuer à être répertorié et téléchargé sur l'App Store d'Apple nécessite une communication et une discussion entre Apple et Tencent pour déterminer la situation future. Software App Store et WeChat Description du problème Le consultant technique du Software App Store a souligné que les développeurs pourraient devoir payer des frais pour mettre des logiciels sur l'Apple Store. Après avoir atteint un certain nombre de téléchargements, Apple devra payer les frais correspondants pour les téléchargements ultérieurs. Apple communique activement avec Tencent,

Tutoriel de génération d'images Deepseek Tutoriel de génération d'images Deepseek Feb 19, 2025 pm 04:15 PM

Deepseek: un puissant outil de génération d'images AI! Deepseek lui-même n'est pas un outil de génération d'images, mais sa puissante technologie de base fournit un support sous-jacent pour de nombreux outils de peinture d'IA. Vous voulez savoir comment utiliser Deepseek pour générer des images indirectement? Veuillez continuer à lire! Générez des images avec des outils AI basés sur Deepseek: Les étapes suivantes vous guideront pour utiliser ces outils: Lancez l'outil de peinture AI: Recherchez et ouvrez un outil de peinture AI basé sur Deepseek (par exemple, recherchez "Simple IA"). Sélectionnez le mode de dessin: sélectionnez "Drawing AI" ou fonction similaire et sélectionnez le type d'image en fonction de vos besoins, tels que "Anime Avatar", "paysage"

Des personnes proches du dossier ont répondu que « WeChat pourrait ne pas prendre en charge l'Apple iPhone 16 » : les rumeurs sont des rumeurs Des personnes proches du dossier ont répondu que « WeChat pourrait ne pas prendre en charge l'Apple iPhone 16 » : les rumeurs sont des rumeurs Sep 02, 2024 pm 10:43 PM

Les rumeurs selon lesquelles WeChat prendrait en charge l'iPhone 16 ont été démystifiées. Merci aux internautes Xi Chuang Jiu Shi et HH_KK pour avoir soumis des indices ! Selon les informations du 2 septembre, des rumeurs courent aujourd'hui selon lesquelles WeChat pourrait ne pas prendre en charge l'iPhone 16, et l'iPhone ne pourra pas utiliser WeChat une fois mis à niveau vers le système iOS 18.2. Selon le « Daily Economic News », des personnes proches du dossier ont appris que cette rumeur était une rumeur. Réponse d'Apple : selon Shell Finance, le consultant technique d'Apple en Chine a répondu que la question de savoir si WeChat peut continuer à être utilisé sur les systèmes iOS ou les appareils Apple, et si WeChat peut continuer à être répertorié et téléchargé dans l'App Store d'Apple, doit être résolue. être résolu entre Apple et Tencent. Ce n'est que par la communication et la discussion que nous pourrons déterminer la situation future. Actuellement, Apple communique activement avec Tencent pour confirmer si Tencent continuera à

Site Web officiel chinois GATEO Site Web officiel chinois GATEO Feb 21, 2025 pm 03:06 PM

Gate.io, une plate-forme de trading de crypto-monnaie de premier plan fondée en 2013, fournit aux utilisateurs chinois un site Web chinois officiel complet. Le site Web fournit un large éventail de services, notamment le trading ponctuel, le trading à terme et les prêts, et offre des fonctionnalités spéciales telles que l'interface chinoise, les ressources riches et le soutien communautaire.

Liste des frais de traitement pour la plateforme de trading OKX Liste des frais de traitement pour la plateforme de trading OKX Feb 15, 2025 pm 03:09 PM

La plateforme de trading OKX offre une variété de tarifs, y compris les frais de transaction, les frais de retrait et les frais de financement. Pour les transactions ponctuelles, les frais de transaction varient en fonction du volume des transactions et du niveau VIP et adoptent le "modèle de marché de marché", c'est-à-dire que le marché facture des frais de traitement inférieurs pour chaque transaction. De plus, OKX propose également une variété de contrats à terme, y compris des contrats standard de devises, des contrats USDT et des contrats de livraison, et la structure des frais de chaque contrat est également différente.

Sesame Open Door Login Enregistrement Entrée Gate.IO Enregistrement d'échange Entrée du site Web officiel Sesame Open Door Login Enregistrement Entrée Gate.IO Enregistrement d'échange Entrée du site Web officiel Mar 04, 2025 pm 04:51 PM

Gate.io (Sesame Open Door) est la principale plate-forme de trading de crypto-monnaie au monde. Le tutoriel couvre des étapes telles que l'enregistrement et la connexion du compte, la certification KYC, la monnaie fiduciaire et la recharge de la monnaie numérique, la sélection des paires de trading, les commandes de transaction limite / commerciale et les commandes et les enregistrements de transaction, vous aidant à démarrer rapidement sur la plate-forme Gate.io pour le trading des crypto-monnaies. Qu'il s'agisse d'un débutant ou d'un vétéran, vous pouvez bénéficier de ce tutoriel et maîtriser facilement les compétences de trading Gate.io.

Application Gateio Exchange Ancienne version GATEIO Exchange App Old Version Télécharger la chaîne de téléchargement Application Gateio Exchange Ancienne version GATEIO Exchange App Old Version Télécharger la chaîne de téléchargement Mar 04, 2025 pm 11:36 PM

Les canaux de téléchargement de l'application GATEIO Exchange pour les anciennes versions, couvrant les marchés d'applications officiels, tiers, les communautés de forum et d'autres canaux.

OUYI Exchange App Download Download Tutorial OUYI Exchange App Download Download Tutorial Mar 21, 2025 pm 05:42 PM

Cet article fournit un guide détaillé pour le téléchargement en toute sécurité de l'application OUYI OKX en Chine. En raison des restrictions sur les magasins d'applications nationales, il est conseillé aux utilisateurs de télécharger l'application via le site officiel d'Ouyi OKX, ou d'utiliser le code QR fourni par le site officiel pour analyser et télécharger. Pendant le processus de téléchargement, assurez-vous de vérifier l'adresse officielle du site Web, de consulter les autorisations d'application, d'effectuer une analyse de sécurité après l'installation et d'activer la vérification à deux facteurs. Pendant l'utilisation, veuillez respecter les lois et réglementations locales, utiliser un environnement de réseau sûr, protéger la sécurité des comptes, être vigilant contre la fraude et investir rationnellement. Cet article est pour référence uniquement et ne constitue pas des conseils d'investissement.

See all articles