Maison interface Web Questions et réponses frontales Comment exporter la table arborescente telle quelle dans Vue

Comment exporter la table arborescente telle quelle dans Vue

Apr 13, 2023 am 10:48 AM

Les tables arborescentes sont une méthode d'affichage courante dans les projets, et Vue est actuellement l'un des frameworks les plus couramment utilisés sur le front-end. Alors, comment exporter la table arborescente telle quelle dans Vue ? Ci-dessous, je présenterai une façon d’y parvenir.

Méthode

Tout d'abord, nous devons installer la bibliothèque xlsx, qui peut exporter des données dans un tableau Excel. Entrez la commande suivante sur la ligne de commande pour installer : xlsx 库,该库能够将数据导出为Excel表格。在命令行中输入以下命令即可安装:

npm install xlsx --save
Copier après la connexion

接着,我们需要封装一个函数来生成Excel文件:

import XLSX from 'xlsx'

export function exportTreeExcel(dataList, columns, fileName) {
  const ws = XLSX.utils.json_to_sheet(getExportData(dataList, columns)) // 将数据转换成excel需要的一个二维数组形式
  const wb = XLSX.utils.book_new()
  XLSX.utils.book_append_sheet(wb, ws, 'Sheet1')
  XLSX.writeFile(wb, `${fileName}.xlsx`)
}

// 数据整理,将树型数据扁平化,去掉树形结构,同时处理成需要导出的字段
function getExportData(dataList, columns) {
  const res = []
  dataList.forEach(item => {
    const tmp = {}
    columns.forEach(col => {
      tmp[col.label] = item[col.prop]
    })
    res.push(tmp)
    if (item.children && item.children.length) { // 如果有子节点,则递归处理
      res.push(...getExportData(item.children, columns))
    }
  })
  return res
}
Copier après la connexion

这段代码中,我们封装了一个函数 exportTreeExcel,它接受三个参数,分别是要导出的数据、列信息和导出文件的名称。在此函数中,我们首先通过调用 getExportData 函数将树形数据扁平化,并提取出需要导出的字段。然后,我们利用 XLSX 库将数据转换成 Excel 的格式,并通过 writeFile 方法将数据写入到文件中。

getExportData 函数用于将树形数据扁平化处理,并提取出需要导出的字段。在此函数中,我们判断当前节点是否存在子节点,如果有,则递归处理其子节点,并将子节点的数据加入到结果数组中。

最后,我们在需要导出树形表格的地方调用 exportTreeExcel 函数即可。

例子:

export default {
  data() {
    return {
      dataList: [
        {
          id: 1,
          name: 'A',
          children: [
            {
              id: 2,
              name: 'A-1',
              children: [
                {
                  id: 3,
                  name: 'A-1-1',
                  children: []
                }
              ]
            }
          ]
        },
        {
          id: 4,
          name: 'B',
          children: []
        }
      ],
      columns: [
        {
          label: '编号',
          prop: 'id'
        },
        {
          label: '名称',
          prop: 'name'
        }
      ]
    }
  },
  methods: {
    exportExcel() {
      exportTreeExcel(this.dataList, this.columns, 'tree-table')
    }
  }
}
Copier après la connexion

在上面的例子中,我们通过调用 exportTreeExcelrrreee

Ensuite, nous devons encapsuler une fonction pour générer un fichier Excel :

rrreee

Dans ce code, nous encapsulons une fonction exportTreeExcel, qui accepte Les trois paramètres sont les données à exporter, les informations sur les colonnes et le nom du fichier d'exportation. Dans cette fonction, nous aplatissons d'abord les données de l'arborescence en appelant la fonction getExportData et extrayons les champs qui doivent être exportés. Ensuite, nous utilisons la bibliothèque XLSX pour convertir les données au format Excel et écrire les données dans le fichier via la méthode writeFile. La fonction

getExportData est utilisée pour aplatir les données de l'arborescence et extraire les champs qui doivent être exportés. Dans cette fonction, nous déterminons si le nœud actuel a des nœuds enfants. Si tel est le cas, traitons de manière récursive ses nœuds enfants et ajoutons les données du nœud enfant au tableau de résultats. 🎜🎜Enfin, nous pouvons appeler la fonction exportTreeExcel partout où nous avons besoin d'exporter la table arborescente. 🎜🎜Exemple : 🎜rrreee🎜Dans l'exemple ci-dessus, nous exportons les données de la table arborescente vers un fichier Excel en appelant la fonction exportTreeExcel. Vous pouvez encapsuler cette fonction dans une bibliothèque d'outils comme dans l'exemple afin qu'elle puisse être facilement appelée dans d'autres composants. 🎜🎜Résumé🎜🎜Ce qui précède explique comment exporter la table arborescente telle quelle dans Vue. Grâce à cette méthode, nous pouvons exporter les données de la table arborescente vers un fichier Excel pour faciliter la visualisation et le traitement par les autres utilisateurs. Si vous disposez d'autres méthodes de mise en œuvre, partagez-les avec nous dans la zone de commentaires. 🎜

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)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois 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)

Qu'est-ce que l'utilisation Effecte? Comment l'utilisez-vous pour effectuer des effets secondaires? Qu'est-ce que l'utilisation Effecte? Comment l'utilisez-vous pour effectuer des effets secondaires? Mar 19, 2025 pm 03:58 PM

L'article traite de l'utilisation Effecte dans React, un crochet pour gérer les effets secondaires comme la récupération des données et la manipulation DOM dans les composants fonctionnels. Il explique l'utilisation, les effets secondaires courants et le nettoyage pour éviter des problèmes comme les fuites de mémoire.

Comment fonctionne l'algorithme de réconciliation React? Comment fonctionne l'algorithme de réconciliation React? Mar 18, 2025 pm 01:58 PM

L'article explique l'algorithme de réconciliation de React, qui met à jour efficacement le DOM en comparant les arbres DOM virtuels. Il traite des avantages de la performance, des techniques d'optimisation et des impacts sur l'expérience utilisateur. Compte de charge: 159

Quelles sont les fonctions d'ordre supérieur en JavaScript, et comment peuvent-ils être utilisés pour écrire du code plus concis et réutilisable? Quelles sont les fonctions d'ordre supérieur en JavaScript, et comment peuvent-ils être utilisés pour écrire du code plus concis et réutilisable? Mar 18, 2025 pm 01:44 PM

Les fonctions d'ordre supérieur dans JavaScript améliorent la concision du code, la réutilisabilité, la modularité et les performances par abstraction, modèles communs et techniques d'optimisation.

Comment fonctionne le currying en JavaScript et quels sont ses avantages? Comment fonctionne le currying en JavaScript et quels sont ses avantages? Mar 18, 2025 pm 01:45 PM

L'article traite du curry dans JavaScript, une technique transformant les fonctions mulguments en séquences de fonctions à argument unique. Il explore la mise en œuvre du currying, des avantages tels que des applications partielles et des utilisations pratiques, améliorant le code

Comment connectez-vous les composants React au magasin Redux à l'aide de Connect ()? Comment connectez-vous les composants React au magasin Redux à l'aide de Connect ()? Mar 21, 2025 pm 06:23 PM

L'article discute de la connexion des composants React à Redux Store à l'aide de Connect (), expliquant MapStateToproprop, MapDispatchToprops et des impacts de performances.

Qu'est-ce que UseContext? Comment l'utilisez-vous pour partager l'état entre les composants? Qu'est-ce que UseContext? Comment l'utilisez-vous pour partager l'état entre les composants? Mar 19, 2025 pm 03:59 PM

L'article explique UseContext dans React, qui simplifie la gestion de l'État en évitant le forage des accessoires. Il traite des avantages tels que les améliorations centralisées de l'État et des performances grâce à des redevances réduites.

Comment empêchez-vous le comportement par défaut dans les gestionnaires d'événements? Comment empêchez-vous le comportement par défaut dans les gestionnaires d'événements? Mar 19, 2025 pm 04:10 PM

L'article discute de la prévention des comportements par défaut dans les gestionnaires d'événements à l'aide de la méthode empêchée dedEfault (), de ses avantages tels que une expérience utilisateur améliorée et des problèmes potentiels tels que les problèmes d'accessibilité.

Comment implémentez-vous les crochets personnalisés dans React? Comment implémentez-vous les crochets personnalisés dans React? Mar 18, 2025 pm 02:00 PM

L'article discute de la mise en œuvre de crochets personnalisés dans React, en se concentrant sur leur création, les meilleures pratiques, les avantages de la performance et les pièges communs à éviter.

See all articles