Inhaltsverzeichnis
Anforderungen ermitteln
Vue.js-Plug-in schreiben
Schreiben der Tabellenkomponente
Tabellenkomponente verwenden
Zusammenfassung
Heim Web-Frontend View.js Grundlegendes VUE3-Tutorial: Verwenden Sie das Vue.js-Plug-in, um Tabellenkomponenten zu kapseln

Grundlegendes VUE3-Tutorial: Verwenden Sie das Vue.js-Plug-in, um Tabellenkomponenten zu kapseln

Jun 16, 2023 am 09:44 AM
vue vuejs table组件

Mit der Popularität der getrennten Entwicklung von Front-End und Back-End haben sich Front-End-Frameworks und -Tools nach und nach zu einem relativ unabhängigen System entwickelt. Unter ihnen hat Vue.js als Marktführer die Aufmerksamkeit und Verwendung von mehr auf sich gezogen und mehr Entwickler. Dieser Artikel basiert auf der Version Vue.js 3.x und stellt die Verwendung des Vue.js-Plug-Ins zum Kapseln einer Tabellenkomponente vor.

Anforderungen ermitteln

Bevor Sie Vue.js zum Kapseln einer Tabellenkomponente verwenden, müssen Sie zunächst die Anforderungen und Funktionen der Komponente ermitteln. Wir können die folgenden Anforderungen auflisten:

  • Unterstützung der dynamischen Eingabe von Daten und Generierung von Tabellen basierend auf Daten
  • Unterstützung der Spaltensortierung basierend auf Tabellenkopfinformationen
  • Unterstützung der Suchfunktion und Herausfiltern von Zieldaten basierend auf Schlüsselwörtern
  • Unterstützung der Paging-Funktion

Nachdem wir die Anforderungen und Funktionen geklärt hatten, begannen wir mit dem Eintritt in die formale Entwicklungsphase.

Vue.js-Plug-in schreiben

In Vue.js ist ein Plug-in ein Javascript-Objekt mit einer Installationsmethode. Wenn das Plug-in registriert ist, wird die Installationsmethode aufgerufen. Mit dieser Methode können wir globale Komponenten, Anweisungen erstellen oder Instanzmethoden usw. hinzufügen.

Wir haben das Plug-in VueTablePlugin genannt, erstellen wir dieses Vue-Plug-in.

const VueTablePlugin = {
  install: function (Vue) {
    // 全局组件
    Vue.component('vue-table', {
      // 组件选项
    })
  }
}
Nach dem Login kopieren

Okay, jetzt, da wir das Vue-Plug-in erstellt haben, fügen wir Komponentenoptionen hinzu.

Schreiben der Tabellenkomponente

Da die Tabellenkomponente die dynamische Datenanzeige und Suche, Sortierung, Paginierung und andere Funktionen unterstützen muss, müssen wir eine Reihe von Prozessen innerhalb der Komponente ausführen. Zuerst können wir einige Optionen und Requisiten der Komponente definieren:

Vue.component('vue-table', {
  props: {
    data: Array,   // 父组件传入的数据
    columns: Array // table头部信息
  },
  data () {
    return {
      searchKey: '',   // 搜索关键字
      sortKey: '',     // 排序关键字
      current: 1,      // 当前页
      pageSize: 5,     // 每页显示数量
    }
  },
  computed: {
    filteredData: function () {
      return this.data.filter((row) => {
        return Object.values(row).some(val => {
          return String(val).includes(this.searchKey)
        })
      })
    },
    sortedData: function () {
      if (!this.sortKey) {
        return this.filteredData
      }
      return this.filteredData.sort((a, b) => {
        a = a[this.sortKey]
        b = b[this.sortKey]
        return a === b ? 0 : a > b ? 1 : -1
      })
    },
    pageCount: function () {
      return Math.ceil(this.filteredData.length / this.pageSize)
    },
    paginatedData: function () {
      const start = (this.current - 1) * this.pageSize
      return this.sortedData.slice(start, start + this.pageSize)
    }
  },
  methods: {
    sortBy (key) {
      this.sortKey = key
      this.current = 1
    },
    prevPage () {
      this.current--
      if (this.current < 1) this.current = 1
    },
    nextPage () {
      this.current++
      if (this.current > this.pageCount) this.current = this.pageCount
    }
  },
  template: `
    <table>
      <thead>
        <tr>
          <th v-for="col in columns"
              :key="col.key"
              @click="sortBy(col.key)"
              :class="{active: sortKey === col.key}">
            {{ col.name }}
          </th>
        </tr>
        <tr>
          <th v-for="col in columns">
            <input type="text" v-model="searchKey">
          </th>
        </tr>
      </thead>
      <tbody>
        <tr v-for="row in paginatedData" :key="row.id">
          <td v-for="col in columns" :key="col.key">
            {{ row[col.key] }}
          </td>
        </tr>
      </tbody>
      <tfoot>
        <tr>
          <td colspan="100%">
            <button @click="prevPage">Prev</button>
            <button @click="nextPage">Next</button>
          </td>
        </tr>
      </tfoot>
    </table>
  `
})
Nach dem Login kopieren

Da wir die Tabellenkomponente in das Plug-In schreiben, müssen wir bei Verwendung dieser Komponente keine Komponenten einführen. Wir müssen das Plug-In nur registrieren Unter jeder Vue-Instanz kann diese Komponente verwendet werden.

Tabellenkomponente verwenden

Nachdem wir oben unser Vue-Plug-in und die Tabellenkomponente erstellt haben, können wir diese Komponente problemlos in jeder Vue-Instanz verwenden. Die spezifischen Vorgänge sind wie folgt:

Führen Sie sie in die Vue-Instanz ein, die diese Vue-Komponente verwendet -table-plugin:

import VueTablePlugin from './path/to/vue-table-plugin.js'
Nach dem Login kopieren

Registrieren Sie dann das Plug-in in der Vue-Instanz:

Vue.use(VueTablePlugin)
Nach dem Login kopieren

Auf diese Weise können Sie die Vue-Table-Komponente problemlos unter der Vue-Instanz verwenden:

<template>
  <div>
    <vue-table :data="tableData" :columns="columns"></vue-table>
  </div>
</template>

<script>
export default {
  data() {
    return {
      tableData: [
        { id: 1, name: 'John Doe', age: 29, occupation: 'Software Engineer' },
        { id: 2, name: 'Jane Doe', age: 30, occupation: 'Graphic Designer' },
        { id: 3, name: 'Aaron Lee', age: 25, occupation: 'Web Developer' },
        { id: 4, name: 'Amanda Smith', age: 27, occupation: 'UI Designer' },
        { id: 5, name: 'Jack Ma', age: 55, occupation: 'Entrepreneur' },
        { id: 6, name: 'Elon Musk', age: 49, occupation: 'Inventor' },
        { id: 7, name: 'Stephen Hawking', age: 76, occupation: 'Physicist' },
        { id: 8, name: 'Albert Einstein', age: 76, occupation: 'Theoretical Physicist' }
      ],
      columns: [
        { name: 'ID', key: 'id' },
        { name: 'Name', key: 'name' },
        { name: 'Age', key: 'age' },
        { name: 'Occupation', key: 'occupation' }
      ]
    }
  }
}
</script>
Nach dem Login kopieren

Auf diese Weise haben wir es abgeschlossen Eine einfache Die Vue-Table-Komponente wird gekapselt und mithilfe des Vue-Plug-Ins verwendet. In der tatsächlichen Produktionsumgebung können wir sie bis zu einem gewissen Grad optimieren und erweitern und eine flexiblere und praktischere Tischkomponente entwickeln.

Zusammenfassung

Das Vue-Plug-In und die Tabellenkomponente in diesem Artikel sind nur ein vorläufiges Paket. In der tatsächlichen Entwicklung müssen sie entsprechend den Anforderungen angepasst und erweitert werden, um den endgültigen Effekt zu erzielen. Es wird empfohlen, die tatsächliche Entwicklung zu üben und zu erweitern, Ihre eigene Komponentenbibliothek ständig zu verbessern und Ihre eigenen Entwicklungsfunktionen zu verbessern.

Das obige ist der detaillierte Inhalt vonGrundlegendes VUE3-Tutorial: Verwenden Sie das Vue.js-Plug-in, um Tabellenkomponenten zu kapseln. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So fügen Sie Funktionen zu Schaltflächen für Vue hinzu So fügen Sie Funktionen zu Schaltflächen für Vue hinzu Apr 08, 2025 am 08:51 AM

Sie können der VUE -Taste eine Funktion hinzufügen, indem Sie die Taste in der HTML -Vorlage an eine Methode binden. Definieren Sie die Methode und schreiben Sie die Funktionslogik in der VUE -Instanz.

So verweisen Sie auf die JS -Datei mit Vue.js So verweisen Sie auf die JS -Datei mit Vue.js Apr 07, 2025 pm 11:27 PM

Es gibt drei Möglichkeiten, sich auf JS -Dateien in Vue.js zu beziehen: Geben Sie den Pfad direkt mit dem & lt; Skript & gt an. Etikett;; Dynamischer Import mit dem montierten () Lebenszyklushaken; und importieren über die Vuex State Management Library.

So verwenden Sie Watch in Vue So verwenden Sie Watch in Vue Apr 07, 2025 pm 11:36 PM

Mit der Watch -Option in Vue.js können Entwickler auf Änderungen in bestimmten Daten anhören. Wenn sich die Daten ändert, löst sich eine Rückruffunktion aus, um Aktualisierungsansichten oder andere Aufgaben auszuführen. Zu den Konfigurationsoptionen gehören unmittelbar, die festlegen, ob ein Rückruf sofort ausgeführt werden soll, und Deep, das feststellt, ob Änderungen an Objekten oder Arrays rekursiv anhören sollen.

So verwenden Sie Bootstrap in Vue So verwenden Sie Bootstrap in Vue Apr 07, 2025 pm 11:33 PM

Die Verwendung von Bootstrap in Vue.js ist in fünf Schritte unterteilt: Startstrap installieren. Bootstrap in main.js. Verwenden Sie die Bootstrap -Komponente direkt in der Vorlage. Optional: benutzerdefinierter Stil. Optional: Verwenden Sie Plug-Ins.

So kehren Sie von Vue zur vorherigen Seite zurück So kehren Sie von Vue zur vorherigen Seite zurück Apr 07, 2025 pm 11:30 PM

VUE.JS hat vier Methoden, um zur vorherigen Seite zurückzukehren: $ router.go (-1) $ router.back () verwendet & lt; Router-Link to = & quot;/& quot; Komponentenfenster.history.back () und die Methodenauswahl hängt von der Szene ab.

Vue realisiert Festzelt-/Text -Scrolling -Effekt Vue realisiert Festzelt-/Text -Scrolling -Effekt Apr 07, 2025 pm 10:51 PM

Implementieren Sie Marquee/Text-Scrolling-Effekte in VUE unter Verwendung von CSS-Animationen oder Bibliotheken von Drittanbietern. In diesem Artikel wird die Verwendung von CSS -Animation vorgestellt: Bildlauftext erstellen und Text mit & lt; div & gt;. Definieren Sie CSS -Animationen und setzen Sie Überlauf: Versteckt, Breite und Animation. Definieren Sie Keyframes, setzen Sie Transformation: Translatex () am Anfang und am Ende der Animation. Passen Sie die Animationseigenschaften wie Dauer, Bildlaufgeschwindigkeit und Richtung an.

So fragen Sie die Version von Vue So fragen Sie die Version von Vue Apr 07, 2025 pm 11:24 PM

Sie können die Vue -Version mit Vue Devtools abfragen, um die Registerkarte VUE in der Konsole des Browsers anzuzeigen. Verwenden Sie NPM, um den Befehl "npm list -g vue" auszuführen. Suchen Sie das Vue -Element im Objekt "Abhängigkeiten" der Datei package.json. Führen Sie für Vue -CLI -Projekte den Befehl "Vue --version" aus. Überprüfen Sie die Versionsinformationen im & lt; Skript & gt; Tag in der HTML -Datei, die sich auf die VUE -Datei bezieht.

So verwenden Sie Funktionsabfangweserven So verwenden Sie Funktionsabfangweserven Apr 08, 2025 am 06:51 AM

Funktionsabfangen in VUE ist eine Technik, mit der die Häufigkeit, mit der eine Funktion eingerufen wird, innerhalb eines bestimmten Zeitraums aufgerufen wird und Leistungsprobleme verhindern. Die Implementierungsmethode lautet: Importieren Sie die Lodash -Bibliothek: importieren {dunounce} aus 'lodash'; Verwenden Sie die Dabounce -Funktion, um eine Intercept -Funktion zu erstellen: const dabouncedFunction = dunounce (() = & gt; { / logical /}, 500); Rufen Sie die Abfangfunktion auf und die Steuerfunktion wird höchstens einmal in 500 Millisekunden aufgerufen.

See all articles