Maison >interface Web >Voir.js >Comment utiliser des filtres et implémenter des filtres personnalisés dans Vue

Comment utiliser des filtres et implémenter des filtres personnalisés dans Vue

王林
王林original
2023-06-09 16:09:223526parcourir

Vue est un framework JavaScript populaire qui est particulièrement apprécié par les développeurs front-end en raison de sa facilité d'apprentissage, de sa facilité d'utilisation et de sa flexibilité. Dans Vue, les filtres sont une fonction très courante qui peut nous aider à gérer la conversion et le formatage de certaines données, rendant ainsi la présentation des données plus claire et plus belle. Cet article présentera l'utilisation des filtres dans Vue et comment implémenter des filtres personnalisés.

1. L'utilisation de filtres dans Vue

Les filtres dans Vue peuvent être utilisés pour filtrer les données à afficher. Ils peuvent être définis via des filtres globaux et des filtres locaux. Les filtres globaux peuvent être utilisés dans n'importe quel composant de l'application, tandis que les filtres locaux ne peuvent être utilisés que dans le composant actuel.

Voici un exemple simple montrant comment utiliser les filtres dans Vue :

<div id="app">
  <p>原始字符串:{{ message }}</p>
  <p>过滤后字符串:{{ message | reverse }}</p>
</div>

<script>
new Vue({
  el: '#app',
  data: {
    message: 'Hello World!'
  },
  filters: {
    reverse: function(value) {
      return value.split('').reverse().join('')
    }
  }
})
</script>

Dans le code ci-dessus, nous avons défini un filtre global inverse qui accepte une chaîne comme paramètre et lui renvoie le résultat inversé. Dans le modèle, nous utilisons le symbole | pour appeler ce filtre, et les données du message sont traitées par le filtre avant de l'afficher.

2. Méthode de mise en œuvre de filtres personnalisés

Dans Vue, nous pouvons personnaliser les filtres pour répondre à des besoins spécifiques. Vous trouverez ci-dessous un exemple de filtre personnalisé qui convertit une chaîne de date en date dans un format spécifié.

<div id="app">
  <p>原始日期:{{ date }}</p>
  <p>转换后日期:{{ date | dateFormat('yyyy-MM-dd') }}</p>
</div>

<script>
new Vue({
  el: '#app',
  data: {
    date: '2021/01/01'
  },
  filters: {
    dateFormat: function(value, format) {
      var date = new Date(value)
      var year = date.getFullYear()
      var month = date.getMonth() + 1
      var day = date.getDate()
      var hour = date.getHours()
      var minute = date.getMinutes()
      var second = date.getSeconds()

      format = format.replace('yyyy', year)
      format = format.replace('MM', pad(month))
      format = format.replace('dd', pad(day))
      format = format.replace('hh', pad(hour))
      format = format.replace('mm', pad(minute))
      format = format.replace('ss', pad(second))

      return format
    }
  }
})

function pad(number) {
  return number < 10 ? '0' + number : number
}
</script>

Dans le code ci-dessus, nous définissons un filtre partiel dateFormat, qui accepte deux paramètres, l'un est la chaîne de date et l'autre est le format de date. Dans la fonction de filtre, nous convertissons la chaîne en date via l'objet Date en JavaScript et la concaténons selon le format spécifié. Parmi eux, nous utilisons un pavé de fonctions de remplissage de zéros pour ajouter zéro devant un seul nombre de mois, jours, heures, minutes et secondes.

Le format du filtre personnalisé est le suivant :

filters: {
  filterName: function(value[, arg1, arg2, ...]) {
    // filter function body
    return filteredValue
  }
}

où filterName est le nom du filtre, value est les données à filtrer et les arg1, arg2, etc. suivants sont des paramètres facultatifs utilisés pour transmettre des données supplémentaires ou définir le format d'attente. La fonction de filtre peut transformer les données d'entrée et renvoyer les résultats filtrés.

Résumé :

Dans cet article, nous avons appris comment utiliser les filtres dans Vue et comment implémenter des filtres personnalisés. Qu'il s'agisse d'un filtre global ou d'un filtre local, il peut nous aider à traiter les données et à les rendre plus belles et plus lisibles. La méthode de mise en œuvre des filtres personnalisés est également très simple. Il suffit de définir la fonction en fonction du format du filtre. J'espère que cet article sera utile à tout le monde.

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:
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