Maison > interface Web > js tutoriel > Comment créer une fonction LongestWord en JavaScript avec explication technique

Comment créer une fonction LongestWord en JavaScript avec explication technique

Mary-Kate Olsen
Libérer: 2024-12-18 14:21:11
original
232 Les gens l'ont consulté

Cara Membuat Fungsi longestWord di JavaScript dengan Penjelasan Teknis

Trouvez le mot le plus long en JavaScript avec longestWord

D'accord, donc cette fois, je veux parler d'une fonction simple mais assez intéressante que j'ai rencontrée en apprenant JavaScript et que j'ai trouvée sur codewars. Le nom de la fonction est le plus longWord. Comme son nom l'indique, cette fonction recherchera et renverra le mot le plus long d'une chaîne.

Je vais vous expliquer pourquoi cette fonction fonctionne, quelles méthodes sont utilisées et les raisons. Allez, passons directement à l'explication détaillée !


Le but de la fonction Mot le plus long

Cette fonction a une tâche simple : elle accepte la saisie sous la forme d'une chaîne contenant plusieurs mots (séparés par des espaces), puis renvoie le mot le plus long. S'il s'avère qu'il y a plus d'un mot de même longueur, cette fonction prendra le dernier mot trouvé.

Un exemple est le suivant :

longestWord("Aku sedang belajar JavaScript yang menyenangkan");
// Output: "menyenangkan"
Copier après la connexion
Copier après la connexion
longestWord("red blue gold");
// Output: "gold"
Copier après la connexion

Code de fonction

Voici le code, il est vraiment court, mais ce qui est cool c'est que dans les coulisses, il se passe beaucoup de choses :

function longestWord(stringOfWords) {
  return stringOfWords
    .split(' ') // Pecah string jadi array kata-kata
    .sort((a, b) => a.length - b.length) // Urutkan berdasarkan panjang
    .slice(-1) // Ambil elemen terakhir (kata terpanjang)
    .toString(); // Ubah jadi string lagi
}
Copier après la connexion

Explication technique

1. Diviser une chaîne en un tableau de mots : .split(' ')

Tout d'abord, la chaîne saisie est divisée en un tableau de mots avec la méthode split(' "). Les espaces dans la chaîne sont donc comme des séparateurs entre les mots.

Par exemple :

"Aku sedang belajar".split(' ');
// Output: ["Aku", "sedang", "belajar"]
Copier après la connexion

Ceci est important car nous ne pouvons pas manipuler directement des chaînes comme des tableaux. Avec split, chaque mot devient un élément de tableau très simple à gérer.


2. Tri des mots par longueur : .sort((a, b) => a.length - b.length)

Après avoir constitué un tableau, nous trions les mots du plus court au plus long en utilisant la méthode de tri.

En quelque sorte, je donne un rappel (a, b) => a.longueur - b.longueur. Essentiellement, je demande à JavaScript de trier les éléments du tableau par longueur.

Le résultat ?

["Aku", "sedang", "belajar"].sort((a, b) => a.length - b.length);
// Output: ["Aku", "sedang", "belajar"]
Copier après la connexion

3. Prenez le mot le plus long : .slice(-1)

Le tableau étant trié, le mot le plus long doit être à la fin du tableau. Ainsi, la fonction slice(-1) consiste à prendre le dernier élément.

Un exemple est le suivant :

["Aku", "sedang", "belajar"].slice(-1);
// Output: ["belajar"]
Copier après la connexion

4. Changez-le à nouveau en chaîne : .toString()

Le résultat de slice(-1) est en fait toujours sous la forme d'un tableau, même s'il ne contient qu'un seul élément. Pour qu'il corresponde au résultat demandé, nous le reconvertissons en chaîne en utilisant toString().

Résultat final :

longestWord("Aku sedang belajar JavaScript yang menyenangkan");
// Output: "menyenangkan"
Copier après la connexion
Copier après la connexion

Pourquoi utiliser ces méthodes ?

  1. split(' ') : Comme les chaînes sont immuables (ne peuvent pas être modifiées directement), je les ai d'abord divisées en un tableau pour qu'elles soient faciles à traiter.
  2. sort() : Le moyen le plus rapide de trouver l'élément le plus grand ou le plus long est de trier d'abord les données.
  3. slice(-1) : Il s'agit d'une astuce simple pour récupérer immédiatement le dernier élément du tableau.
  4. toString() : Puisque la sortie finale doit être une chaîne, c'est la dernière étape.

Pour moi, la fonction longestWord est comme un bon exercice pour mémoriser certaines méthodes importantes en JavaScript, notamment pour travailler avec des chaînes et des tableaux. Grâce à cette fonction, je comprends également mieux le fonctionnement du fractionnement, du tri, du slice et du toString.

Si vous avez d'autres idées pour résoudre ce problème, ou peut-être souhaitez-vous une optimisation plus poussée, discutons-en ensemble dans la colonne des 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!

source:dev.to
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal