<datalist></datalist>
pour la complétion automatique L'élément HTML5 <datalist></datalist>
fournit un moyen simple d'offrir des suggestions de complétion automatique pour les entrées de formulaire. Il fonctionne en associant un élément <datalist></datalist>
avec un élément <input>
à l'aide de l'attribut list
. L'élément <datalist></datalist>
lui-même contient des éléments <option></option>
, chacun représentant une suggestion possible. Lorsque l'utilisateur commence à taper le champ <input>
associé, le navigateur affiche une liste déroulante contenant les options du <datalist></datalist>
.
Voici comment vous le faites:
<code class="html"><input type="text" list="browsers" name="browser"> <datalist id="browsers"> <option value="Chrome"> </option> <option value="Firefox"> </option> <option value="Safari"> </option> <option value="Edge"> </option> <option value="Opera"> </option></datalist></code>
Dans cet exemple, l'élément <input>
avec le jeu d'attribut list
sur "Browsers" est lié à l'élément <datalist></datalist>
avec les "navigateurs" ID. Le navigateur affichera automatiquement les options de la <datalist></datalist>
car l'utilisateur type dans le champ de saisie. L'utilisateur peut ensuite sélectionner une suggestion dans la liste déroulante ou continuer à taper pour saisir manuellement une valeur. Notez que l'élément <datalist></datalist>
lui-même ne s'affiche pas directement sur la page; Il ne sert qu'à source de suggestions pour l'entrée liée.
<datalist></datalist>
suggestions Malheureusement, le style des suggestions offerts par l'élément <datalist></datalist>
directement à l'aide de CSS est limité. Vous ne pouvez pas styliser directement la liste déroulante elle-même avec des sélecteurs CSS standard. Les fournisseurs de navigateurs ont implémenté différents styles de rendu, et il n'y a pas de moyen cohérent de remplacer ces styles sur tous les navigateurs. Les tentatives de styliser les éléments <datalist></datalist>
ou ses <option></option>
avec CSS ont souvent des effets incohérents ou sans effet.
Cependant, vous pouvez influencer indirectement l'apparence. Par exemple, vous pouvez styliser l'élément <input>
lui-même, ce qui affectera le contexte visuel global des suggestions de saisie semi-automatique. Vous pourriez changer sa police, sa bordure ou son rembourrage. Mais le style directement de la liste déroulante reste difficile et dépendant du navigateur. Cette limitation est un inconvénient significatif de l'utilisation de l'élément Native <datalist></datalist>
pour les exigences de style complexes.
<datalist></datalist>
Bien que l'élément <datalist></datalist>
bénéficie d'un large soutien entre les navigateurs modernes, vous devez être conscient de certaines nuances de compatibilité:
<datalist></datalist>
. Pour les navigateurs plus âgés, vous aurez besoin d'un mécanisme de secours, comme l'utilisation de JavaScript pour créer une fonctionnalité de saisie semi-automatique personnalisée. La détection des fonctionnalités à l'aide de JavaScript peut vous aider à déterminer si le navigateur prend en charge <datalist></datalist>
avant de s'y fier.<datalist></datalist>
avec JavaScript Vous pouvez remplir dynamiquement les options dans un élément <datalist></datalist>
à l'aide de JavaScript. Cela permet de créer des suggestions de saisie automatique plus flexibles et basées sur les données. Vous pouvez récupérer des données à partir d'un serveur, d'une base de données ou de toute autre source.
Voici un exemple:
<code class="javascript">const datalist = document.getElementById('myDatalist'); const options = ['apple', 'banana', 'cherry', 'date']; options.forEach(option => { const optionElement = document.createElement('option'); optionElement.value = option; datalist.appendChild(optionElement); });</code>
Cet extrait de code sélectionne l'élément <datalist></datalist>
avec l'ID "MyDatalist" puis itère via un tableau d'options. Pour chaque option, il crée un nouvel élément <option></option>
, définit sa valeur et l'ajouta au <datalist></datalist>
. Cette approche vous permet de construire les suggestions dynamiquement, offrant une expérience de saisie semi-automatique plus réactive et plus adaptable. N'oubliez pas d'adapter ce code à votre source de données spécifique et à votre mécanisme de récupération. Par exemple, vous pouvez utiliser fetch
pour récupérer les données d'une API.
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!