Framework7 - Guide rapide

Framework7 est un framework gratuit et open source pour le HTML mobile. Il est utilisé pour développer des applications mobiles hybrides ou des applications Web pour les appareils iOS et Android.

Framework7 a été introduit en 2014. La dernière version 1.4.2 a été publiée en février 2016 sous licence MIT.

Pourquoi utiliser Framework7?

  • Il est plus facile de développer des applications pour iOS et Android.
  • La courbe d'apprentissage pour Framework7 est très simple.
  • Il a de nombreux widgets / composants pré-stylisés.
  • Il a des bibliothèques d'aide intégrées.

traits

  • Framework7 est un framework open source et gratuit.

  • Framework7 a une syntaxe jQuery facile et familière pour démarrer sans aucun délai.

  • Pour contrôler le délai de clic pour les interfaces utilisateur tactiles, Framework7 dispose d' une bibliothèque FastClick intégrée.

  • Framework7 a une disposition de système de grille intégrée pour organiser vos éléments de manière réactive.

  • Framework7 charge dynamiquement les pages des modèles via une API de routeur flexible .

Avantages

  • Framework7 ne dépend d'aucune bibliothèque tierce, même pour la manipulation DOM. Au lieu de cela, il a son propre DOM7 personnalisé.

  • Framework7 peut également être utilisé avec les frameworks Angular et React .

  • Vous pouvez commencer à créer des applications une fois que vous connaissez le HTML, le CSS et certains JavaScript de base.

  • Il prend en charge un développement plus rapide via Bower .

  • Il est facile de développer des applications pour iOS et Android sans l'apprendre.

Désavantages

  • Framework7 ne prend en charge que les plates-formes comme iOS et Android.

  • La prise en charge par la communauté en ligne du framework Framework7 est inférieure à celle d'iOS et d'Andriod.

Dans ce chapitre, nous discuterons de la façon d'installer et de configurer Framework7.

Vous pouvez télécharger le Framework7 de deux manières -

Télécharger à partir du référentiel Github Framework7

Vous pouvez installer le Framework7, en utilisant Bower comme indiqué ci-dessous -

bower install framework7

Après une installation réussie de Framework7, vous devez suivre les étapes ci-dessous pour utiliser Framework7 dans votre application -

Step 1 - Vous devez installer gulp-cli pour créer des versions de développement et dist de Framework7 à l'aide de la commande suivante.

npm install gulp-cli

Le cli signifie Command Line Utility pour Gulp.

Step 2 - Le Gulp doit être installé globalement à l'aide de la commande suivante.

npm install --global gulp

Step 3- Ensuite, installez le gestionnaire de packages NodeJS, qui installe les programmes de nœuds qui facilitent la spécification et la liaison des dépendances. La commande suivante est utilisée pour installer le npm.

npm install

Step 4 - La version de développement de Framework7 peut être générée à l'aide de la commande suivante.

npm build

Step 5- Une fois que vous avez créé la version de développement de Framework7, commencez à créer l'application à partir du dossier dist / à l'aide de la commande suivante.

npm dist

Step 6 - Conservez votre dossier d'application sur le serveur et exécutez la commande suivante pour la navigation entre les pages de votre application.

gulp server

Télécharger la bibliothèque Framework7 à partir de CDN

Un CDN ou Content Delivery Network est un réseau de serveurs conçu pour servir des fichiers aux utilisateurs. Si vous utilisez un lien CDN dans votre page Web, il transfère la responsabilité de l'hébergement des fichiers de vos propres serveurs vers une série de serveurs externes. Cela offre également l'avantage que si un visiteur de votre page Web a déjà téléchargé une copie de Framework7 à partir du même CDN, il n'aura pas à être retéléchargé. Vous pouvez inclure les fichiers CDN suivants dans le document HTML.

Les CDN suivants sont utilisés dans un iOS App layout -

<link rel = "stylesheet" 
   href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />

Il est utilisé pour inclure la bibliothèque CSS Framework7 iOS à votre application.

<link rel = "stylesheet" 
   href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />

Il est utilisé pour inclure les styles de couleur liés à Framework7 iOS à votre application.

Les CDN suivants sont utilisés dans Android/Material App Layout -

<script src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>

Il est utilisé pour inclure la bibliothèque Framework7 JS dans votre application.

<script src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.material.min.css"></script>

Il est utilisé pour inclure le style du matériel Framework7 dans votre application.

Nous utilisons les versions CDN de la bibliothèque tout au long de ce didacticiel. Nous utilisons AMPPS (AMPPS est une pile WAMP, MAMP et LAMP d'Apache, MySQL, MongoDB, PHP, Perl & Python) pour exécuter tous nos exemples.

Exemple

L'exemple suivant montre l'utilisation d'une application simple dans le Framework7, qui affichera la boîte d'alerte avec le message personnalisé lorsque vous cliquez sur la barre de navigation.

<!DOCTYPE html>
<html>
   
   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>My App</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>
   
   <body>
      //you can control the background color of the Status bar
      <div class = "statusbar-overlay"></div>
      <div class = "panel-overlay"></div>
      
      <div class = "panel panel-right panel-reveal">
         <div class = "content-block">
            <p>Contents goes here...</p>
         </div>
      </div>
      
      <div class = "views">
         <div class = "view view-main">
            <div class = "navbar">
               <div class = "navbar-inner">
                  <div class = "center sliding">My App</div>
                  <div class = "right">
                     <a href = "#" class = "link icon-only open-panel">
                        <i class = "icon icon-bars"></i>
                     </a>
                  </div>
               </div>
            </div>
            
            <div class = "pages navbar-through toolbar-through">
               <div data-page = "index" class = "page">
                  <div class = "page-content">
                     <p>This is simple application...</p>
                     <div class = "list-block">
                        <ul>
                           <li>
                              <a href = "envirmnt_about.html" class = "">
                                 <div class = "item-content">
                                    <div class = "item-inner">
                                       <div class = "item-title">Blog</div>
                                    </div>
                                 </div>
                              </a>
                           </li>
                        </ul>
                     </div>
                  </div>
               </div>
            </div>
            
            <div class = "toolbar">
               <div class = "toolbar-inner">
                  <a href = "#" class = "link">First Link</a>
                  <a href = "#" class = "link">Second Link</a>
               </div>
            </div>
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
      
      <script>
         // here initialize the app
         var myApp = new Framework7();

         // If your using custom DOM library, then save it to $$ variable
         var $$ = Dom7;

         // Add the view
         var mainView = myApp.addView('.view-main', {
            
            // enable the dynamic navbar for this view:
            dynamicNavbar: true
         });

         //use the 'pageInit' event handler for all pages
         $$(document).on('pageInit', function (e) {
         
            //get page data from event data
            var page = e.detail.page;

            if (page.name === 'blog') {
            
               // you will get below message in alert box when page with data-page attribute is equal to "about"
               myApp.alert('Here its your About page');
            }
         })
      </script>
   </body>

</html>

Ensuite, créez une autre page HTML ie envirmnt_about.html comme indiqué ci-dessous -

envirmnt_about.html

<div class = "navbar">
   <div class = "navbar-inner">
      <div class = "left">
         <a href = "#" class = "back link">
            <i class = "icon icon-back"></i>
            <span>Back</span>
         </a>
      </div>
      
      <div class = "center sliding">My Blog</div>
      <div class = "right">
         <a href = "#" class = "link icon-only open-panel">
            <i class = "icon icon-bars"></i>
         </a>
      </div>
   </div>
</div>

<div class = "pages">
   <div data-page = "blog" class = "page">
      <div class = "page-content">
         <div class = "content-block">
            <h2>My Blog</h2>
            <p>Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book.</p>
         </div>
      </div>
   </div>
</div>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous framework7_environment.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/framework7_environment.html et la sortie s'affiche comme indiqué ci-dessous.

  • Lorsque vous cliquez sur la barre de navigation, il affichera la boîte d'alerte avec le message personnalisé.

La description

Framework7 fournit différents types de mises en page pour votre application. Il prend en charge trois types de dispositions Navbar / Toolbar -

S.Non Types de disposition et description
1 Disposition statique

La mise en page statique est le plus souvent utilisée de type mise en page et comprend une barre de navigation et une barre d'outils, qui peuvent être un contenu de page déroulant et chaque page contient sa propre barre de navigation et sa propre barre d'outils.

2 Disposition fixe

La disposition fixe comprend sa propre barre de navigation et sa propre barre d'outils, qui peuvent être visibles à l'écran et ne peuvent pas faire défiler la page.

3 À travers la mise en page

Dans cette mise en page, la barre de navigation et la barre d'outils semblent fixes pour toutes les pages d'une vue unique.

4 Disposition mixte

Vous pouvez mélanger les différents types de mises en page dans la vue unique.

Pas de barre de navigation / barre d'outils

Si vous ne souhaitez pas utiliser la barre de navigation et la barre d'outils, n'incluez pas les classes appropriées ( navbar-fixed , navbar-through , toolbar-fixed , toolbar-through ) dans la page / pages / vue.

La description

Dans ce chapitre, étudions la barre de navigation . C'est un généralement placé en haut d'un écran contenant le titre de la page et des éléments de navigation.

Navbar se compose de trois parties dont chacune peut contenir n'importe quel contenu HTML, mais il est suggéré de les utiliser de la manière indiquée ci-dessous -

  • Left- Il est conçu pour placer des icônes de lien arrière ou un lien texte unique.

  • Center - Il est utilisé pour afficher le titre de la page ou les liens de l'onglet.

  • Right- Cette partie est similaire à la partie gauche .

Le tableau suivant montre en détail l'utilisation de la barre de navigation -

S.Non Types et description de la barre de navigation
1 Barre de navigation de base

Une barre de navigation de base peut être créée à l'aide des classes navbar , navbar-inner , left , center et right .

2 Navbar avec liens

Pour utiliser des liens dans la partie gauche et droite de votre barre de navigation, ajoutez simplement la balise <a> avec le lien de classe .

3 Liens multiples

Pour utiliser plusieurs liens, ajoutez simplement quelques <a class = "link"> plus à la partie de votre choix.

4 Liens avec texte et icônes

Les liens peuvent être fournis avec des icônes et des textes en ajoutant des classes pour les icônes et en enveloppant le texte du lien avec l' élément <span> .

5 Liens avec uniquement des icônes

Les liens de la barre de navigation peuvent être fournis avec uniquement des icônes en ajoutant une classe d' icônes uniquement aux liens.

6 Application et méthodes d'affichage associées

Lors de l'initialisation de la vue , framework7 vous permet d'utiliser les méthodes disponibles pour la barre de navigation.

sept Masquer automatiquement la barre de navigation

La barre de navigation peut être masquée / affichée automatiquement pour certaines pages chargées en Ajax où la barre de navigation n'est pas requise.

La description

La barre d'outils fournit un accès facile à d'autres pages en utilisant les éléments de navigation en bas de l'écran.

Vous pouvez utiliser la barre d'outils de deux manières, comme indiqué dans le tableau -

S.Non Types de barres d'outils et description
1 Masquer la barre de tâches

Vous pouvez masquer la barre d'outils automatiquement lorsque vous chargez les pages en utilisant le no-toolbar classe à la page chargée.

2 Barre d'outils inférieure

Placez la barre d'outils au bas de la page en utilisant le toolbar-bottom classe.

Méthodes de la barre d'outils

Les méthodes disponibles suivantes peuvent être utilisées avec les barres d'outils -

S.Non Méthodes et description de la barre d'outils
1

myApp.hideToolbar(toolbar)

Il masque la barre d'outils spécifiée.

2

myApp.showToolbar(toolbar)

Il montre la barre d'outils spécifiée.

3

view.hideToolbar()

Il masque la barre d'outils spécifiée dans la vue.

4

view.showToolbar()

Il affiche la barre d'outils spécifiée dans la vue.

Exemple

L'exemple suivant illustre l'utilisation de la disposition de la barre d'outils dans Framework7.

Tout d'abord, nous allons créer une page HTML appelée toolbar.html comme indiqué ci-dessous -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Toolbar Layout</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
         
            <div class = "navbar">
               <div class = "navbar-inner">
                  <div class = "center sliding">Toolbar Layout</div>
               </div>
            </div>
            
            <div class = "pages navbar-through">
               <div data-page = "index" class = "page with-subnavbar">
                  <div class = "page-content">
                     <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. 
                     Suspendisse at nibh felis. Nunc consequat diam et tellus tempor gravida. 
                     Donec hendrerit aliquet risus, ut tempor purus dictum sit amet. Aenean 
                     sagittis interdum leo in molestie. Aliquam sodales in diam eu consectetur. 
                     Sed posuere a orci id imperdiet.</p>
                     
                     <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. 
                     Suspendisse at nibh felis. Nunc consequat diam et tellus tempor gravida. 
                     Donec hendrerit aliquet risus, ut tempor purus dictum sit amet. Aenean 
                     sagittis interdum leo in molestie. Aliquam sodales in diam eu consectetur. 
                     Sed posuere a orci id imperdiet.</p>
                  </div>
               </div>
            </div>
            
            <div class = "toolbar">
               <div class = "toolbar-inner">
                  <a href = "#" class = "link">Link 1</a>
                  <a href = "#" class = "link">Link 2</a>
                  <a href = "#" class = "link">Link 3</a>
               </div>
            </div>
            
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
         
      <script>
         // here initialize the app
         var myApp = new Framework7();

         // If your using custom DOM library, then save it to $$ variable
         var $$ = Dom7;

         // Add the view
         var mainView = myApp.addView('.view-main', {
         
            // enable the dynamic navbar for this view
            dynamicNavbar: true
         });
      </script>
   </body>

</html>

Maintenant, initialisez votre application et vos vues dans le fichier JS personnalisé toolbar.js.

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous toolbar.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/toolbar.html et la sortie s'affiche comme indiqué ci-dessous.

La description

Framework 7 permet de rechercher les éléments en utilisant la classe searchbar .

Paramètres de la barre de recherche

S.Non Paramètres et description Type Défaut
1

searchList

Il recherche le sélecteur CSS ou l'élément HTML de la liste.

chaîne ou élément HTML -
2

searchIn

Vous pouvez rechercher les éléments d'affichage de liste des sélecteurs CSS, ainsi que les éléments en passant des classes .item-title , .item-text .

chaîne ".item-title"
3

found

Il recherche le sélecteur CSS ou l'élément HTML à l'aide de l'élément "found". De plus, il utilise l' élément .searchbar-found s'il n'y a aucun élément spécifié.

chaîne ou élément HTML -
4

notfound

Il recherche le sélecteur CSS ou l'élément HTML à l'aide de l'élément "not-found". De plus, il utilise l' élément .searchbar-not-found si aucun élément n'est spécifié.

chaîne ou élément HTML -
5

overlay

Il recherche le sélecteur CSS ou l'élément HTML à l'aide de l'élément "searchbar overlay" et utilise l'élément .searchbar-overlay , s'il n'y a pas d'élément spécifié.

chaîne ou élément HTML -
6

ignore

Vous pouvez ignorer le sélecteur CSS pour les éléments en utilisant la barre de recherche.

chaîne ".searchbar-ignore"
sept

customSearch

Lorsqu'elle est activée, la barre de recherche ne recherchera dans aucun des blocs de liste spécifiés par searchList et vous serez autorisé à utiliser la fonctionnalité de recherche personnalisée.

booléen faux
8

removeDiacritics

Lors de la recherche d'un élément, supprimez les signes diacritiques en activant ce paramètre.

booléen faux
9

hideDividers

Ce paramètre masquera les séparateurs d'éléments et le titre du groupe, s'il n'y a pas d'éléments.

booléen vrai
dix

hideGroups

Ce paramètre masquera les groupes, s'il n'y a aucun élément trouvé dans les groupes d'affichage de liste.

booléen vrai

Rappels de la barre de recherche

S.Non Rappels et description Type Défaut
1

onSearch

Cette méthode déclenchera la fonction de rappel lors de la recherche.

les fonctions) -
2

onEnable

Cette méthode déclenchera la fonction de rappel lorsque la barre de recherche deviendra active.

les fonctions) -
3

onDisable

Cette méthode déclenchera la fonction de rappel lorsque la barre de recherche devient inactive.

les fonctions) -
4

onClear

Cette méthode déclenchera la fonction de rappel lorsque vous cliquerez sur l'élément "effacer".

les fonctions) -

Propriétés de la barre de recherche

S.Non Propriétés et description
1

mySearchbar.params

Représente les paramètres initialisés passés avec l'objet.

2

mySearchbar.query

Recherche la requête actuelle.

3

mySearchbar.searchList

Définit le bloc de liste de recherche.

4

mySearchbar.container

Définit le conteneur de la barre de recherche avec l'élément HTML.

5

mySearchbar.input

Définit l'entrée de la barre de recherche avec l'élément HTML.

6

mySearchbar.active

Il définit si la barre de recherche est activée ou désactivée.

Méthodes de la barre de recherche

S.Non Méthodes et description
1

mySearchbar.search(query);

Cette méthode recherche la requête passée.

2

mySearchbar.enable();

Il active la barre de recherche.

3

mySearchbar.disable();

Cela désactive la barre de recherche.

4

mySearchbar.clear();

Vous pouvez effacer la requête et les résultats de la recherche.

5

mySearchbar.destroy();

Il détruit l'instance de la barre de recherche.

Événements JavaScript de la barre de recherche

S.Non Description de l'évenement Cible
1

search

Vous pouvez déclencher cet événement lors de la recherche d'éléments.

<div class = "list-block">
2

clearSearch

Cet événement sera déclenché lorsque l'utilisateur cliquera sur l'élément clearSearch.

<div class = "list-block">
3

enableSearch

Lorsque la barre de recherche devient activée, cet événement sera déclenché.

<div class = "list-block">
4

disableSearch

Lorsque la barre de recherche est désactivée et que l'utilisateur clique sur le bouton d'annulation ou sur l'élément "barre de recherche en superposition", cet événement est déclenché.

<div class = "list-block">

Exemple

L'exemple suivant illustre l'utilisation de la barre de recherche lors du défilement dans le Framework7 -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Search Bar Layout</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
            <div class = "pages navbar-fixed">
               <div data-page = "home" class = "page">
               
                  <div class = "navbar">
                     <div class = "navbar-inner">
                        <div class = "center sliding">Search Bar Layout</div>
                     </div>
                  </div>
                  
                  <form data-search-list = ".list-block-search" data-search-in = ".item-title" 
                     class = "searchbar searchbar-init">
                     <div class = "searchbar-input">
                        <input type = "search" placeholder = "Search"><a href = "#" 
                           class = "searchbar-clear"></a>
                     </div>
                     <a href = "#" class = "searchbar-cancel">Cancel</a>
                  </form>
                  
                  <div class = "searchbar-overlay"></div>
                  
                  <div class = "page-content">
                     <div class = "content-block searchbar-not-found">
                        <div class = "content-block-inner">No element found...</div>
                     </div>
                     
                     <div class = "list-block list-block-search searchbar-found">
                        <ul>
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">India</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Argentina</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Belgium</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Brazil</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Canada</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Colombia</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Denmark</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Ecuador</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">France</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Germany</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Greece</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Haiti</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Hong Kong</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Iceland</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Ireland</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Jamaica</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Japan</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Kenya</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Kuwait</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Libya</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Liberia</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Malaysia</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Mauritius</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Mexico</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Namibia</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">New Zealand</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Oman</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Paraguay</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Philippines</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Russia</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Singapore</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">South Africa</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Thailand</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">United Kingdom</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Vatican City</div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Zimbabwe</div>
                              </div>
                           </li>
                        </ul>
                     </div>
                     
                  </div>
               </div>
            </div>
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
      
      <script>
         var myApp = new Framework7();
         var mainView = myApp.addView('.view-main');
      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus search_bar.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/search_bar.html et la sortie s'affiche comme indiqué ci-dessous.

  • Si l'élément contenu dans la liste est entré dans la barre de recherche, il affiche cet élément particulier de la liste.

  • Si l'élément autre que les éléments contenus dans la liste est saisi, il n'affiche aucun élément trouvé.

La description

L'iOS 7+ vous permet de créer des applications en plein écran qui pourraient créer un problème lorsque votre barre d'état chevauche votre application. Framework7 résout ce problème en détectant si votre application est en mode plein écran ou non. Si votre application est en mode plein écran, le Framework7 ajoutera automatiquement la classe with-statusbar-overlay à <html> (ou supprimera si l'application n'est pas en mode plein écran) et vous devez ajouter la classe statusbar-overlay dans <body> comme indiqué dans le code suivant -

<html class = "with-statusbar-overlay">
...
   <body>
      <div class = "statusbar-overlay"></div>
      ...

Par défaut, <div> sera toujours masqué et fixé en haut de votre écran. Il ne sera visible que lorsque l'application est en mode plein écran et que la classe with-statusbar-overlay est ajoutée à <html> .

Exemple

L'exemple suivant montre l'utilisation de la barre d'état dans le Framework7 -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>My App</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>

   <body>
      <div class = "statusbar-overlay"></div>
      <div class = "panel-overlay"></div>
      
      <div class = "panel panel-right panel-reveal">
         <div class = "content-block">
            <p>Contents goes here...</p>
         </div>
      </div>
      
      <div class = "views">
         <div class = "view view-main">
            <div class = "navbar">
               <div class = "navbar-inner">
                  <div class = "center sliding">My App</div>
                  
                  <div class = "right">
                     <a href = "#" class = "link icon-only open-panel"><i class = "icon icon-bars"></i></a>
                  </div>
                  
               </div>
            </div>
            
            <div class = "pages navbar-through toolbar-through">
               <div data-page = "index" class = "page">
                  <div class = "page-content">
                     <p>This is simple application...</p>
                     <p>page contents goes here!!!</p>
                  </div>
               </div>
            </div>
            
            <div class = "toolbar">
               <div class = "toolbar-inner">
                  <a href = "#" class = "link">First Link</a>
                  <a href = "#" class = "link">Second Link</a>
               </div>
            </div>
            
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
      
      <script>
         // here initialize the app
         var myApp = new Framework7();

         // If your using custom DOM library, then save it to $$ variable
         var $$ = Dom7;

         // Add the view
         var mainView = myApp.addView('.view-main', {
            // enable the dynamic navbar for this view:
            dynamicNavbar: true
         });

         //use the 'pageInit' event handler for all pages
         $$(document).on('pageInit', function (e) {
            //get page data from event data
            var page = e.detail.page;
         })
      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code html ci-dessus sous status_bar.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML comme http: //localhost/status_bar.html et la sortie s'affiche comme indiqué ci-dessous.

L'exemple montre l'utilisation du statusbar-overlay, qui vous permet de créer des applications en plein écran lorsque votre barre d'état chevauche l'application.

La description

Le panneau latéral se déplace vers la gauche ou la droite de l'écran pour afficher le contenu. Framework7 vous permet d'inclure jusqu'à 2 panneaux (panneau latéral droit et panneau latéral gauche) à votre application. Vous devez ajouter des panneaux au début du <body> , puis choisir l'effet d'ouverture en appliquant les classes répertoriées suivantes -

  • panel-reveal - Cela fera sortir tout le contenu de l'application.

  • panel-cover - Cela rendra le panneau superposé sur le contenu de l'application.

Par exemple, le code suivant montre comment utiliser les classes ci-dessus -

<body>
   <!-- First add Panel's overlay which will overlays app while panel is opened -->
   <div class = "panel-overlay"></div>
 
   <!-- Left panel -->
   <div class = "panel panel-left panel-cover">
      panel's content
   </div>
 
   <!-- Right panel -->
   <div class = "panel panel-right panel-reveal">
      panel's content
   </div>
 
</body>

Le tableau suivant présente les types de panneaux pris en charge par Framework77 -

S.Non Type et description
1 Ouvrir et fermer les panneaux

Une fois que vous avez ajouté le panneau et les effets, nous devons ajouter des fonctionnalités pour ouvrir et fermer les panneaux.

2 Événements du panel

Pour détecter la manière dont un utilisateur interagit avec le panneau, vous pouvez utiliser les événements du panneau.

3 Ouvrir les panneaux avec glisser

Framework7 vous offre la possibilité d'ouvrir le panneau avec un geste de balayage .

4 Le panneau est ouvert?

Nous pouvons déterminer si le panneau est ouvert ou non en utilisant le with-panel[position]-[effect] règle.

La description

Les blocs de contenu peuvent être utilisés pour ajouter du contenu supplémentaire avec un format différent.

Exemple

L'exemple suivant montre l'utilisation du bloc de contenu dans Framework7 -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Content Block</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
            <div class = "pages">
               <div data-page = "home" class = "page navbar-fixed">
                  
                  <div class = "navbar">
                     <div class = "navbar-inner">
                        <div class = "left"> </div>
                        <div class = "center">Content Block</div>
                        <div class = "right"> </div>
                     </div>
                  </div>
                  
                  <div class = "page-content">
                     <p>This is out side of content block!!!</p>
                     
                     <div class = "content-block">
                        <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium 
                        doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis 
                        et quasi architecto beatae vitae dicta sunt explicabo.</p>
                     </div>
                     
                     <div class = "content-block">
                        <div class = "content-block-inner">This is another text block wrapped with "content-block-inner"</div>
                     </div>
                     
                     <div class = "content-block-title">Content Block Title</div>
                     
                     <div class = "content-block">
                        <p>Praesent nec imperdiet diam. Maecenas vel lectus porttitor, consectetur 
                        magna nec, viverra sem. Aliquam sed risus dolor. Morbi tincidunt ut libero id sodales. 
                        Integer blandit varius nisi quis consectetur.</p>
                     </div>
                     
                     <div class = "content-block-title">This is another long content block title</div>
                     
                     <div class = "content-block">
                        <div class = "content-block-inner">
                           <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem 
                           accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo 
                           inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.</p>
                        </div>
                     </div>
                     
                     <div class = "content-block-title">Content Block Inset</div>
                     
                     <div class = "content-block inset">
                        <div class = "content-block-inner">
                           <p>Donec et nulla auctor massa pharetra adipiscing ut sit amet sem. 
                           Suspendisse molestie velit vitae mattis tincidunt. Ut sit amet quam mollis, 
                           vulputate turpis vel, sagittis felis. </p>
                        </div>
                     </div>
                     
                     <div class = "content-block-title">Content Block Tablet Inset</div>
                     
                     <div class = "content-block tablet-inset">
                        <div class = "content-block-inner">
                           <p>Donec et nulla auctor massa pharetra adipiscing ut sit amet sem.
                           Suspendisse molestie velit vitae mattis tincidunt. Ut sit amet quam mollis, 
                           vulputate turpis vel, sagittis felis. </p>
                        </div>
                     </div>
                     
                  </div>
               </div>
            </div>
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
         
      <script>
         var myApp = new Framework7();
         var mainView = myApp.addView('.view-main');
      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous content_block.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/content_block.html et la sortie s'affiche comme indiqué ci-dessous.

  • Le code ajoute une mise en forme supplémentaire et l'espacement requis pour le contenu du texte.

La description

Framework7 fournit différents types de types de grille pour placer le contenu selon les besoins de l'utilisateur.

La grille de disposition fournit différents types de taille de colonnes, comme décrit dans le tableau suivant -

S.Non Classe Classe de table Largeur
1 col-5 tablette-5 5%
2 col-10 tablette-10 dix%
3 col-15 tablette-15 15%
4 col-20 tablette-20 20%
5 col-25 tablette-25 25%
6 col-30 tablette-30 30%
sept col-33 tablette-33 33,3%
8 col-35 tablette-35 35%
9 col-40 tablette-40 40%
dix col-45 tablette-45 45%
11 col-50 tablette-50 50%
12 col-55 tablette-55 55%
13 col-60 tablette-60 60%
14 col-65 tablette-65 65%
15 col-66 tablette-66 66,6%
16 col-70 tablette-70 70%
17 col-75 tablette-75 75%
18 col-80 tablette-80 80%
19 col-85 tablette-85 85%
20 col-90 tablette-90 90%
21 col-95 tablette-95 95%
21 col-100 tablette-100 100%
22 col-auto tablette-auto Largeur égale

Exemple

L'exemple suivant fournit la disposition de la grille pour placer votre contenu selon vos besoins dans Framework7 -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Layout Grid</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
         
      <style>
         div[class* = "col-"] {
            background: #fff;
            text-align: center;
            color: #000;
            border: 1px solid #D8D8D8;
         }
         .row {
            margin-bottom: 10px;
         }
      </style>
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
         
            <div class = "navbar">
               <div class = "navbar-inner">
                  <div class = "center sliding">Layout Grid</div>
               </div>
            </div>
            
            <div class = "pages">
               <div data-page = "index" class = "page navbar-fixed">
                  <div class = "page-content">
                     <div class = "content-block-title">Columns with gutter</div>
                     
                     <div class = "content-block">
                        <div class = "row">
                           <div class = "col-50">col 1</div>
                           <div class = "col-50">col 2</div>
                        </div>
                        
                        <div class = "row">
                           <div class = "col-25">col 1</div>
                           <div class = "col-25">col 2</div>
                           <div class = "col-25">col 3</div>
                           <div class = "col-25">col 4</div>
                        </div>
                        
                        <div class = "row">
                           <div class = "col-33">col 1</div>
                           <div class = "col-33">col 2</div>
                           <div class = "col-33">col 3</div>
                        </div>
                        
                        <div class = "content-block-title">Columns without gutter</div>
                        
                        <div class = "content-block">
                           <div class = "row no-gutter">
                              <div class = "col-50">col 1</div>
                              <div class = "col-50">col 2</div>
                           </div>
                           
                           <div class = "row no-gutter">
                              <div class = "col-25">col 1</div>
                              <div class = "col-25">col 2</div>
                              <div class = "col-25">col 3</div>
                              <div class = "col-25">col 4</div>
                           </div>
                           
                           <div class = "row no-gutter">
                              <div class = "col-33">col 1</div>
                              <div class = "col-33">col 2</div>
                              <div class = "col-33">col 3</div>
                           </div>
                        </div>
                     
                        <div class = "content-block-title">Nested Columns</div>
                        <div class = "content-block">
                           <div class = "row">
                              
                              <div class = "col-50">
                                 col 1
                                 <div class = "row">
                                    <div class = "col-40">col 2</div>
                                    <div class = "col-60">col 3</div>
                                 </div>
                              </div>
                                 
                              <div class = "col-50">
                                 col 1
                                 <div class = "row">
                                    <div class = "col-75">col 2</div>
                                    <div class = "col-25">col 3</div>
                                 </div>
                              </div>
                                 
                           </div>
                        </div>
                           
                        <div class = "content-block-title">Columns With Different Equal Width</div>
                           
                        <div class = "content-block">
                           <div class = "row">
                              <div class = "col-100 tablet-50">col 1</div>
                              <div class = "col-100 tablet-50">col 2</div>
                           </div>
                              
                           <div class = "row">
                              <div class = "col-50 tablet-25">col 1</div>
                              <div class = "col-50 tablet-25">col 2</div>
                              <div class = "col-50 tablet-25">col 3</div>
                              <div class = "col-50 tablet-25">col 4</div>
                           </div>
                              
                           <div class = "row">
                              <div class = "col-100 tablet-40">col 1</div>
                              <div class = "col-50 tablet-60">col 2</div>
                              <div class = "col-50 tablet-60">col 3</div>
                              <div class = "col-100 tablet-40">col 4</div>
                           </div>
                        </div>
                           
                        <div class = "content-block-title">Columns With Equal Width</div>
                           
                        <div class = "content-block">
                           <div class = "row">
                              <div class = "col-auto">col-1</div>
                              <div class = "col-auto">col-2</div>
                              <div class = "col-auto">col-3</div>
                              <div class = "col-auto">col-4</div>
                           </div>
                              
                           <div class = "row no-gutter">
                              <div class = "col-auto">col-1</div>
                              <div class = "col-auto">col-2</div>
                              <div class = "col-auto">col-3</div>
                              <div class = "col-auto">col-4</div>
                           </div>
                        </div>
                           
                     </div>
                  </div>
               </div>
            </div>
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
      
      <script>
         var myApp = new Framework7();
         var mainView = myApp.addView('.view-main');
      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous layout_grid.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/layout_grid.html la sortie s'affiche comme indiqué ci-dessous.

  • Ce code fournit différents types de types de grille pour placer le contenu selon les besoins de l'utilisateur.

La description

Framework7 fournit différents types de superpositions pour travailler avec les applications en douceur. Le tableau suivant répertorie certaines des superpositions Framework7 -

S.Non Type de superposition et description
1 Modal

Modal est une petite fenêtre qui affiche le contenu de sources distinctes sans quitter la fenêtre parente.

2 Apparaitre

Popup est une boîte contextuelle qui affiche le contenu lorsque l'utilisateur clique sur l'élément.

3 Popover

Pour gérer la présentation du contenu temporaire, le composant popover peut être utilisé.

4 Feuille d'action

La feuille d'action est utilisée pour présenter à l'utilisateur un ensemble de possibilités sur la façon de gérer une tâche donnée.

5 Écran de connexion

L'écran de connexion en superposition est utilisé pour afficher le format de l'écran de connexion qui peut être utilisé dans une page ou une fenêtre contextuelle ou comme superposition autonome.

6 Modal de sélection

Le sélecteur modal est utilisé pour sélectionner un contenu personnalisé similaire au sélecteur de calendrier.

La description

Preloader dans Framework7 est fait avec Scalable Vector Graphic (SVG) et animé avec CSS, ce qui le rend facilement redimensionnable. Preloader est disponible en deux couleurs -

  • la valeur par défaut est un fond clair
  • un autre est un fond sombre

Vous pouvez utiliser la classe de préchargement dans votre HTML comme indiqué ci-dessous -

Exemple

L'exemple suivant montre l'utilisation du préchargeur dans le Framework7 -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Panel Events</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
            <div class = "pages">
               <div data-page = "home" class = "page navbar-fixed">
               
                  <div class = "navbar">
                     <div class = "navbar-inner">
                        <div class = "left"> </div>
                        <div class = "center">Framework7 Preloader</div>
                        <div class = "right"> </div>
                     </div>
                  </div>
                  
                  <div class = "page-content">
                     <div class = "content-block row">
                        <div class = "col-25"><span class = "preloader"></span><br>Default Preloader</div>
                        <div class = "col-25 col-dark"><span class = "preloader preloader-white"></span><br>White Preloader</div>
                        <div class = "col-25"><span style = "width:42px; height:42px" class = "preloader"></span><br>Big Preloader</div>
                        <div class = "col-25 col-dark"><span style = "width:42px; height:42px" class = "preloader preloader-white"></span><br>White Preloader</div>
                     </div>
                  </div>
                  
               </div>
            </div>
         </div>
      </div>
      
      <style>.col-25{padding:5px;text-align:center;}.col-dark{background:#222;}</style>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
         
      <script>
         var myApp = new Framework7();
      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous preloader.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/preloader.html et la sortie s'affiche comme indiqué ci-dessous.

  • Ce code affiche l'indicateur de préchargement, qui est fait avec SVG et animé avec CSS.

La description

Les barres de progression peuvent être utilisées pour montrer le chargement des actifs ou la progression d'une tâche aux utilisateurs. Vous pouvez spécifier la barre de progression à l'aide de la classe progressbar . Lorsque l'utilisateur ne sait pas combien de temps le processus de chargement sera là pour la requête, vous pouvez utiliser la classe progressbar-infinite .

API JavaScript de la barre de progression

La barre de progression peut être utilisé avec l'API JavaScript afin de spécifier show , cacher et progresser les propriétés en utilisant les méthodes suivantes : -

S.Non Méthodes Description et paramètres
1 myApp.setProgressbar (container , progress, speed)

Il définit la barre de progression de la progression d'une tâche.

  • container - C'est une chaîne ou un élément HTML qui définit le conteneur de l'élément de barre de progression.

  • progress - Il représente au format entier et définit la progression d'une tâche.

  • speed - Il représente au format entier et spécifie la durée de l'avancement d'une tâche.

2 myApp.hideProgressbar (contain er)

Il masque la barre de progression.

  • container - C'est une chaîne ou un élément HTML qui définit le conteneur de l'élément de barre de progression.

3 myApp.showProgressbar (contai ner, progress, color)

Il affiche la barre de progression.

  • container - C'est une chaîne ou un élément HTML qui définit le conteneur de l'élément de barre de progression.

  • progress - Il représente au format entier et définit la progression d'une tâche.

  • speed - Il représente au format entier et spécifie la durée de l'avancement d'une tâche.

Exemple

L'exemple suivant affiche une barre de progression animée déterminée et indéterminée pour indiquer l'activité dans Framework7 -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Progress Bar</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.material.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.material.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
            <div class = "pages">
               <div data-page = "home" class = "page navbar-fixed">
               
                  <div class = "navbar">
                     <div class = "navbar-inner">
                        <div class = "center">Progress Bar</div>
                     </div>
                  </div>
                  
                  <div class = "page-content">
                     <div class = "content-block-title">Determinate Progress Bar</div>
                     <div class = "content-block">
                        <div class = "content-block-inner">
                           <p>Inline determinate progress bar:</p>
                           
                           <div class = "progressbar-inline">
                              <p><span data-progress = "10" class = "progressbar"></span></p>
                              
                              <p class = "buttons-row">
                                 <a href = "#" data-progress = "25" class = "button button-raised">25%</a>
                                 <a href = "#" data-progress = "50" class = "button button-raised">50%</a>
                                 <a href = "#" data-progress = "75" class = "button button-raised">75%</a>
                                 <a href = "#" data-progress = "100" class = "button button-raised">100%</a>
                              </p>
                           </div>
                           
                           <p>Loads and hides the determinate progress bar:</p>
                           <div class = "progressbar-load-hide">
                              <p><a href = "#" class = "button button-raised">Start Loading</a></p>
                           </div>
                           
                           <p>Displays the determinate progress bar on top:</p>
                           <p class = "progressbar-overlay"><a href = "#" class = "button button-raised">Start Loading</a></p>
                        </div>
                     </div>
                     
                     <div class = "content-block-title">Infinite Progress Bar</div>
                     <div class = "content-block">
                        <div class = "content-block-inner">
                           <p>Inline infinite progress bar:</p>
                           
                           <p><span class = "progressbar-infinite"></span></p>
                           
                           <p>Displays the infinite progress bar in multiple colors:</p>
                           
                           <p><span class = "progressbar-infinite color-multi"></span></p>
                           
                           <p>Displays the infinite progress bar on top:</p>
                           
                           <p class = "progressbar-infinite-overlay"><a href = "#" class = "button button-raised">Start Loading</a></p>
                           
                           <p>Displays the infinite progress bar in multiple colors on top:</p>
                           
                           <p class = "progressbar-infinite-multi-overlay"><a href = "#" class = "button button-raised">Start Loading</a></p>
                        </div>
                     </div>
                     
                     <div class = "content-block-title">Different types of colored progress bars:</div>
                     <div class = "list-block">
                        <ul>
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "5" class = "progressbar color-red"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "10" class = "progressbar color-pink"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "20" class = "progressbar color-deeppurple"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "30" class = "progressbar color-blue"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "40" class = "progressbar color-cyan"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "50" class = "progressbar color-green"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "60" class = "progressbar color-lime"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "70" class = "progressbar color-amber"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "80" class = "progressbar color-deeporange"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "90" class = "progressbar color-gray"></div>
                              </div>
                           </li>
                           
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div data-progress = "100" class = "progressbar color-black"></div>
                              </div>
                           </li>
                        </ul>
                     </div>
                     
                  </div>
               </div>
            </div>
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
         
      <script>
         var myApp = new Framework7({
            material: true
         });
         
         var $$ = Dom7;

         $$('.progressbar-inline .button').on('click', function () {
            var progress = $$(this).attr('data-progress');
            var progressbar = $$('.progressbar-inline .progressbar');
            myApp.setProgressbar(progressbar, progress);
         });
         
         $$('.progressbar-load-hide .button').on('click', function () {
            var container = $$('.progressbar-load-hide p:first-child');
            
            //it doesn't load if another progresbar is loading
            if (container.children('.progressbar').length) return;

            myApp.showProgressbar(container, 0);

            var progress = 0;
            function simulateLoading() {
               setTimeout(function () {
                  var progressBefore = progress;
                  progress += Math.random() * 20;
                  myApp.setProgressbar(container, progress);
                  if (progressBefore < 100) {
                     simulateLoading();
                  }
                  else myApp.hideProgressbar(container);
               }, Math.random() * 200 + 200);
            }
            simulateLoading();
         });
         
         $$('.progressbar-overlay .button').on('click', function () {
            var container = $$('body');
            if (container.children('.progressbar, .progressbar-infinite').length) return;
            myApp.showProgressbar(container, 0, 'orange');
            var progress = 0;
            
            function simulateLoading() {
               setTimeout(function () {
                  var progressBefore = progress;
                  progress += Math.random() * 20;
                  myApp.setProgressbar(container, progress);
                  if (progressBefore < 100) {
                     simulateLoading();
                  }
                  //hides the progressbar
                  else myApp.hideProgressbar(container);
               }, Math.random() * 200 + 200);
            }
            simulateLoading();
         });
         
         $$('.progressbar-infinite-overlay .button').on('click', function () {
            var container = $$('body');
            if (container.children('.progressbar, .progressbar-infinite').length) return;
            myApp.showProgressbar(container, 'yellow');
            setTimeout(function () {
               myApp.hideProgressbar();
            }, 3000);
         });
         
         $$('.progressbar-infinite-multi-overlay .button').on('click', function () {
            var container = $$('body');
            if (container.children('.progressbar, .progressbar-infinite').length) return;
               myApp.showProgressbar(container, 'multi');
               setTimeout(function () {
               myApp.hideProgressbar();
            }, 3000);
         });
      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous progress_bar.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/progress_bar.html et la sortie s'affiche comme indiqué ci-dessous.

  • L'exemple affiche la barre de progression, qui indique combien de temps une opération prendra pour terminer le processus et affiche les différents types de barres de progression pour indiquer l'activité.

La description

Les vues de liste sont de puissants composants d'interface utilisateur qui présentent les données dans une liste déroulante de plusieurs lignes. Le Framework7 fournit différents types d'affichage de liste pour fonctionner avec votre application. Le tableau suivant répertorie certaines des vues de liste Framework7 -

S.Non Types et description
1 Vue en liste

Les vues de liste sont de puissants composants d'interface utilisateur, qui présentent les données dans une liste déroulante contenant plusieurs lignes.

2 Liste de contacts

La liste de contacts est un type d'affichage de liste, qui peut être utilisé pour afficher la liste des contacts de personnes.

3 Affichage de la liste des médias

La vue de la liste des médias est utilisée pour afficher des structures de données complexes telles que des produits, des services, des informations sur les utilisateurs.

4 Balayer

Le balayage vous permet de révéler les actions de menu masquées en faisant glisser les éléments de la liste.

5 Liste triable

La liste triable est un type de vue de liste, qui trie les éléments de la vue de liste.

6 Liste virtuelle

Liste virtuelle un type de vue de liste, qui comprend des listes d'un grand nombre d'éléments de données sans diminuer leurs performances.

La description

L'accordéon est un élément de contrôle graphique affiché sous la forme d'une liste d'éléments empilés. Chaque accordéon peut être étendu ou étiré pour révéler le contenu associé à cet accordéon.

Disposition pliable

Lorsque vous utilisez un seul élément réductible séparé, vous devez omettre l' élément wrapper liste accordéon .

Voici une structure de mise en page pliable -

<!-- Single collapsible element ------>
<div class = "accordion-item">
   <div class = "accordion-item-toggle"></div>
   <div class = "accordion-item-content"></div>
</div>

<!-- Separate collapsible element -->
<div class = "accordion-item">
   <div class = "accordion-item-toggle"></div>
   <div class = "accordion-item-content"></div>
</div>

Les classes suivantes sont utilisées pour l'accordéon dans Framework7 -

S.Non Classes et description
1

accordion-list

C'est une classe facultative, qui contient un groupe de liste d'éléments d'accordéon.

2

accordion-item

C'est une classe obligatoire pour un seul objet d'accordéon.

3

accordion-item-toggle

C'est une classe obligatoire utilisée pour développer le contenu des objets d'accordéon.

4

accordion-item-content

C'est une classe obligatoire utilisée pour le contenu d'objet d'accordéon caché.

5

accordion-item-expanded

C'est un seul objet accordéon étendu.

API JavaScript d'accordéon

Les méthodes de l'API JavaScript sont utilisées pour ouvrir et fermer l'accordéon par programmation.

Il contient les méthodes API JavaScript suivantes -

  • myApp.accordionOpen(item) - Utilisé pour ouvrir l'accordéon.

  • myApp.accordionClose(item) - Utilisé pour fermer l'accordéon.

  • myApp.accordionToggle(item) - Utilisé pour basculer l'accordéon.

Toutes les méthodes contiennent un paramètre appelé item qui est un élément HTML ou une chaîne de accordéon-item.

Événements d'accordéon

L'accordéon contient quatre événements répertoriés dans le tableau suivant -

S.Non un événement Cible et description
1 ouvert

Accordion item

Lorsque vous ouvrez une animation, cet événement est déclenché.

2 ouvert

Accordion item

Lorsque l'ouverture d'une animation est terminée, cet événement sera déclenché.

3 Fermer

Accordion item

Lorsque vous fermez une animation, cet événement est déclenché.

4 fermé

Accordion item

Lorsque la fermeture d'une animation est terminée, cet événement sera déclenché.

Vue de liste d'accordéon

Dans la vue de liste d'accordéon, vous pouvez utiliser l' élément lien d' élément au lieu de bascule accordéon .

<div class = "list-block accordion-list">
   <ul>
      <li class = "accordion-item">
         <a href = "" class = "item-link item-content">
            <div class = "item-inner">
               <div class = "item-title">1st Item</div>
            </div>
         </a>
         <div class = "accordion-item-content">Content for 1st Item...</div>
      </li>
      
      <li class = "accordion-item">
         <a href = "" class = "item-link item-content">
            <div class = "item-inner">
               <div class = "item-title">2nd Item</div>
            </div>
         </a>
         <div class = "accordion-item-content">Content for 2nd Item...</div>
      </li>
   </ul>
</div>

Exemple

L'exemple suivant illustre l'utilisation de l'accordéon dans le Framework7 -

<!DOCTYPE html>
<html>
   <head>
      <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no, minimal-ui">
      <meta name="apple-mobile-web-app-capable" content="yes">
      <meta name="apple-mobile-web-app-status-bar-style" content="black">
      <title>Accordion</title>
      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css">
      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css">
   </head>
   <body>
      <div class="views">
         <div class="view view-main">
            <div class="pages">
               <div data-page="home" class="page navbar-fixed">
                  <div class="navbar">
                     <div class="navbar-inner">
                        <div class="left"> </div>
                        <div class="center">Accordion</div>
                        <div class="right"> </div>
                     </div>
                  </div>
                  <div class="page-content">
                     <div class="content-block-title">List of Programming Lagauges</div>
                     <div class="list-block accordion-list">
                        <ul>
                           <li class="accordion-item">
                              <a href="#" class="item-content item-link">
                                 <div class="item-inner">
                                    <div class="item-title">C</div>
                                 </div>
                              </a>
                              <div class="accordion-item-content">
                                 <div class="content-block">
                                    <p>C is a general-purpose, procedural, imperative computer programming language developed in 1972 by Dennis M. Ritchie at the Bell Telephone Laboratories to develop the UNIX operating system. C is the most widely used computer language. It keeps fluctuating at number one scale of popularity along with Java programming language, which is also equally popular and most widely used among modern software programmers.</p>
                                 </div>
                              </div>
                           </li>
                           <li class="accordion-item">
                              <a href="#" class="item-content item-link">
                                 <div class="item-inner">
                                    <div class="item-title">C++</div>
                                 </div>
                              </a>
                              <div class="accordion-item-content">
                                 <div class="content-block">
                                    <p>C++ is a middle-level programming language developed by Bjarne Stroustrup starting in 1979 at Bell Labs. C++ runs on a variety of platforms, such as Windows, Mac OS, and the various versions of UNIX.
                                       This reference will take you through simple and practical approach while learning C++ Programming language.
                                    </p>
                                 </div>
                              </div>
                           </li>
                           <li class="accordion-item">
                              <a href="#" class="item-content item-link">
                                 <div class="item-inner">
                                    <div class="item-title">Java</div>
                                 </div>
                              </a>
                              <div class="accordion-item-content">
                                 <div class="content-block">
                                    <p>Java is a high-level programming language originally developed by Sun Microsystems and released in 1995. Java runs on a variety of platforms, such as Windows, Mac OS, and the various versions of UNIX. This tutorial gives a complete understanding of Java.
                                       This reference will take you through simple and practical approach while learning Java Programming language.
                                    </p>
                                 </div>
                              </div>
                           </li>
                        </ul>
                     </div>
                     <div class="content-block-title">Separate Collapsibles</div>
                     <div class="list-block">
                        <ul>
                           <li class="accordion-item">
                              <a href="#" class="item-content item-link">
                                 <div class="item-inner">
                                    <div class="item-title">C</div>
                                 </div>
                              </a>
                              <div class="accordion-item-content">
                                 <div class="content-block">
                                    <p >C is a general-purpose, procedural, imperative computer programming language developed in 1972 by Dennis M. Ritchie at the Bell Telephone Laboratories to develop the UNIX operating system. C is the most widely used computer language. It keeps fluctuating at number one scale of popularity along with Java programming language, which is also equally popular and most widely used among modern software programmers.</p>
                                 </div>
                              </div>
                           </li>
                           <li class="accordion-item">
                              <a href="#" class="item-content item-link">
                                 <div class="item-inner">
                                    <div class="item-title">C++</div>
                                 </div>
                              </a>
                              <div class="accordion-item-content">
                                 <div class="content-block">
                                    <p>C++ is a middle-level programming language developed by Bjarne Stroustrup starting in 1979 at Bell Labs. C++ runs on a variety of platforms, such as Windows, Mac OS, and the various versions of UNIX.
                                       This reference will take you through simple and practical approach while learning C++ Programming language.
                                    </p>
                                 </div>
                              </div>
                           </li>
                           <li class="accordion-item">
                              <a href="#" class="item-content item-link">
                                 <div class="item-inner">
                                    <div class="item-title">Java</div>
                                 </div>
                              </a>
                              <div class="accordion-item-content">
                                 <div class="content-block">
                                    <p>Java is a high-level programming language originally developed by Sun Microsystems and released in 1995. Java runs on a variety of platforms, such as Windows, Mac OS, and the various versions of UNIX. This tutorial gives a complete understanding of Java.
                                       This reference will take you through simple and practical approach while learning Java Programming language.
                                    </p>
                                 </div>
                              </div>
                           </li>
                        </ul>
                     </div>
                     <div class="content-block-title">Custom Accordion</div>
                     <div class="content-block accordion-list custom-accordion">
                        <div class="accordion-item">
                           <div class="accordion-item-toggle"><i class="icon icon-plus">+</i><i class="icon icon-minus">-</i><span>C</span></div>
                           <div class="accordion-item-content">
                              <p>C is a general-purpose, procedural, imperative computer programming language developed in 1972 by Dennis M. Ritchie at the Bell Telephone Laboratories to develop the UNIX operating system. C is the most widely used computer language. It keeps fluctuating at number one scale of popularity along with Java programming language, which is also equally popular and most widely used among modern software programmers.</p>
                           </div>
                        </div>
                        <div class="accordion-item">
                           <div class="accordion-item-toggle"><i class="icon icon-plus">+</i><i class="icon icon-minus">-</i><span>C++</span></div>
                           <div class="accordion-item-content">
                              <p>C++ is a middle-level programming language developed by Bjarne Stroustrup starting in 1979 at Bell Labs. C++ runs on a variety of platforms, such as Windows, Mac OS, and the various versions of UNIX.
                                 This reference will take you through simple and practical approach while learning C++ Programming language.
                              </p>
                           </div>
                        </div>
                        <div class="accordion-item">
                           <div class="accordion-item-toggle"><i class="icon icon-plus">+</i><i class="icon icon-minus">-</i><span>Java</span></div>
                           <div class="accordion-item-content">
                              <p>Java is a high-level programming language originally developed by Sun Microsystems and released in 1995. Java runs on a variety of platforms, such as Windows, Mac OS, and the various versions of UNIX. This tutorial gives a complete understanding of Java.
                                 This reference will take you through simple and practical approach while learning Java Programming language.
                              </p>
                           </div>
                        </div>
                     </div>
                  </div>
               </div>
            </div>
         </div>
      </div>
      <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
      <style>.custom-accordion{padding-left:0;padding-right:0;}.custom-accordion .accordion-item-toggle{padding:0px 15px;height:44px;line-height:44px;font-size:17px;color:#000;border-bottom:1px solid rgba(0,0,0,0.15);cursor:pointer;}.custom-accordion .accordion-item-toggle:active{background:rgba(0,0,0,0.15);}.custom-accordion .accordion-item-toggle span{display:inline-block;margin-left:15px;}.custom-accordion .accordion-item:last-child .accordion-item-toggle{border-bottom:none;}.custom-accordion .icon-plus,.custom-accordion .icon-minus{display:inline-block;width:22px;height:22px;border:1px solid #000;border-radius:100%;line-height:20px;text-align:center;}.custom-accordion .icon-minus{display:none;}.custom-accordion .accordion-item-expanded .icon-minus{display:inline-block;}.custom-accordion .accordion-item-expanded .icon-plus{display:none;}.custom-accordion .accordion-item-content{padding:0px 15px;}</style>
      <script>
         // here initialize the app
         var myApp = new Framework7();

         // If your using custom DOM library, then save it to $$ variable
         var $$ = Dom7;

         // Add the view
         var mainView = myApp.addView('.view-main', {
         // enable the dynamic navbar for this view:
         dynamicNavbar: true
         });
      </script>
   </body>
</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous accordion.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/accordion.html et la sortie s'affiche comme indiqué ci-dessous.

  • L'exemple fournit une mise en page pliable, qui peut être développée pour afficher le contenu associé à l'accordéon.

La description

Les cartes contiennent des informations organisées liées à un seul sujet, comme une photo, un lien et du texte. Le tableau suivant présente les types de cartes Framework7 -

S.Non Types et description
1 Disposition HTML de la carte

La mise en page HTML de base de la carte utilise des classes de carte pour organiser ses éléments.

2 Vue de liste avec cartes

Vous pouvez utiliser des cartes comme éléments d'affichage de liste en ajoutant la classe cards-list à <div class = "list-block"> .

La description

La puce est un petit bloc d'entité, qui peut contenir une photo, une petite chaîne de titre et de courtes informations.

Mise en page HTML des puces

Le code suivant montre la disposition HTML de base de la puce utilisée dans Framework7 -

<div class = "chip">
   <div class = "chip-media">
      <img src = "http://lorempixel.com/100/100/people/9/">
   </div>
   
   <div class = "chip-label">Jane Doe</div>
   <a href = "#" class = "chip-delete"></a>
</div>

La mise en page HTML ci-dessus contient de nombreuses classes répertoriées ci-dessous -

  • chips - C'est le conteneur à copeaux.

  • chip-media- Il s'agit de l'élément multimédia de la puce qui peut contenir des images, un avatar ou une icône. C'est facultatif.

  • card-label - C'est l'étiquette de texte de la puce.

  • card-delete - Il s'agit du lien facultatif d'icône de suppression d'une puce.

Exemple

L'exemple suivant représente les entités telles que les albums, les éléments de carte, etc. avec une photo et de brèves informations -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Chips HTML Layout</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.material.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.material.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
            <div class = "pages">
               
               <div class = "page navbar-fixed">
                  <div class = "navbar">
                     <div class = "navbar-inner">
                        <div class = "center">Chips HTML Layout</div>
                     </div>
                  </div>
                  
                  <div class = "page-content">
                     <div class = "content-block-title">Chips With Text</div>
                     <div class = "content-block">
                        <div class = "chip">
                           <div class = "chip-label">Chip one</div>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-label">Chip two</div>
                        </div>
                     </div>
                     
                     <div class = "content-block-title">Chips with icons</div>
                     
                     <div class = "content-block">
                        <div class = "chip">
                           <div class = "chip-media bg-blue"><i class = "icon icon-form-calendar"></i></div>
                           <div class = "chip-label">Set Date</div>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-media bg-purple"><i class = "icon icon-form-email"></i></div>
                           <div class = "chip-label">Sent Mail</div>
                        </div>
                     </div>
                     
                     <div class = "content-block-title">Contact Chips</div>
                     
                     <div class = "content-block">
                        <div class = "chip">
                           <div class = "chip-media"><img src = "/framework7/images/pic.jpg"></div>
                           <div class = "chip-label">James Willsmith</div>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-media"><img src = "/framework7/images/pic2.jpg"></div>
                           <div class = "chip-label">Sunil Narayan</div>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-media bg-pink">R</div>
                           <div class = "chip-label">Raghav</div>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-media bg-teal">S</div>
                           <div class = "chip-label">Sharma</div>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-media bg-red">Z</div>
                           <div class = "chip-label">Zien</div>
                        </div>
                     </div>
                     
                     <div class = "content-block-title">Deletable Chips</div>
                     
                     <div class = "content-block">
                        <div class = "chip">
                           <div class = "chip-label">Chip one</div>
                           <a href = "#" class = "chip-delete"></a>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-media bg-teal">S</div>
                           <div class = "chip-label">Sharma</div>
                           <a href = "#" class = "chip-delete"></a>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-media bg-purple"><i class = "icon icon-form-email"></i></div>
                           <div class = "chip-label">Sent</div>
                           <a href = "#" class = "chip-delete"></a>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-media"><img src = "/framework7/images/pic.jpg"></div>
                           <div class = "chip-label">James Willsmith</div>
                           <a href = "#" class = "chip-delete"></a>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-label">Chip two</div>
                           <a href = "#" class = "chip-delete"></a>
                        </div>
                        
                        <div class = "chip">
                           <div class = "chip-media bg-green">R</div>
                           <div class = "chip-label">Raghav</div>
                           <a href = "#" class = "chip-delete"></a>
                        </div>
                     </div>
                     
                  </div>
               </div>
            </div>
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
         
      <style>
      </style>
      
      <script>
         var myApp = new Framework7 ({
            material: true
         });
         
         var $$ = Dom7;
         $$('.chip-delete').on('click', function (e) {
            e.preventDefault();
            var chip = $$(this).parents('.chip');
             
            myApp.confirm('Do you want to delete this Chip?', function () {
               chip.remove();
            });
         });
      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous cards_html_layout.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/cards_html_layout.html et la sortie s'affiche comme indiqué ci-dessous.

  • L'exemple représente les entités complexes dans de petits blocs tels que les albums, les éléments de carte, l'image publiée, qui contient une photo, une chaîne de titre et de brèves informations.

La description

Framework7 fournit un groupe de boutons prêts à l'emploi en ajoutant simplement les classes appropriées aux liens ou aux boutons d'entrée.

S.Non Types et description
1 Boutons de thème iOS

Framework7 fournit de nombreux boutons de thème iOS, qui peuvent être utilisés en appliquant des classes appropriées.

2 Boutons de thème de matériau

Le thème du matériau fournit de nombreux boutons à utiliser dans votre application en utilisant les classes appropriées.

La description

Framework7 fournit un bouton d'action flottant pour une action promue. Ils apparaissent sous la forme d'une icône encerclée flottante sur l'interface utilisateur. Il a les comportements de mouvement qui contiennent le morphing , le lancement et le transfert d'un point d'ancrage .

Le bouton d'action flottant n'est pris en charge que dans le thème Matériau.

Le tableau suivant répertorie les types de boutons d'action utilisés dans Framework7 -

S.Non Types et description
1 Disposition du bouton d'action flottant

C'est très simple; il vous suffit de le placer en tant qu'enfant de la page ou de la vue .

2 Transformer en popover

Si vous souhaitez ouvrir le popover en cliquant sur le bouton d'action flottant, vous pouvez utiliser la classe de bouton flottant à popover .

3 Numérotation rapide

Vous pouvez appeler des actions associées en cliquant sur le bouton d'action flottant à l'aide de la numérotation abrégée .

La description

Les formulaires sont utilisés pour interagir avec les utilisateurs et collectent des données auprès des utilisateurs Web à l'aide de champs de texte, de cases à cocher, de boutons radio, etc.

Framework7 fournit différents types d'éléments de formulaire pour travailler avec les applications en douceur, comme spécifié dans le tableau ci-dessous -

S.Non Type de superposition et description
1 Éléments de formulaire

Les éléments de formulaire sont utilisés pour créer de belles mises en page de formulaire.

2 Cases à cocher et radios

L' extension d' affichage de liste vous permet de créer des cases à cocher et des entrées radio dans Framework7.

3 Sélection intelligente

La sélection intelligente est un moyen simple de modifier les sélections de formulaire en pages dynamiques en utilisant des groupes de cases à cocher et d'entrées radio.

4 Éléments désactivés

Les éléments peuvent être désactivés en appliquant la classe désactivée à l'élément ou en ajoutant des attributs désactivés pour l'élément de formulaire.

5 Données de formulaire

Framework7 a très peu de méthodes utiles, ce qui facilite le travail avec les formulaires.

6 Stockage de formulaires

Il est facile avec le stockage de formulaires de stocker et d'analyser automatiquement les données de formulaires sur les pages chargées en Ajax.

sept Soumettre le formulaire Ajax

Framework7 vous permet d'envoyer des données automatiquement en utilisant Ajax.

La description

Les onglets sont des ensembles de contenu groupé logiquement qui nous permettent de basculer rapidement entre eux et d'économiser de l'espace comme des accordéons.

Disposition des onglets

Le code suivant définit la disposition des onglets -

<!-- Tabs wrapper, shoud have "tabs" class.It is a required element -->
<div class = "tabs">
   <!-- The tab, should have "tab" class and unique id attribute -->
   
   <!-- The tab is active by default - "active" class -->
   <div class = "tab active" id = "tab1">
      ...  The content for Tab 1 goes here ...
   </div>
   
   <!-- The second tab, should have "tab" class and unique id attribute -->
   <div class = "tab" id = "tab2">
      ... The content for Tab 2 goes here ...
   </div>
</div>

Où -

  • <div class = "tabs">- C'est un wrapper obligatoire pour tous les onglets. Si nous manquons cela, les onglets ne fonctionneront pas du tout.

  • <div class = "tab"> - C'est un seul onglet, qui devrait avoir unique id attribut.

  • <div class = "tab active">- Il s'agit d'un seul onglet actif, qui utilise une classe active supplémentaire pour rendre l'onglet visible (actif).

Basculer entre les onglets

Vous pouvez utiliser certains contrôleurs dans la disposition des onglets, de sorte que l'utilisateur puisse basculer entre eux.

Pour cela, vous devez créer des liens (balises <a>) avec une classe tab-link et un attribut href égal à l' attribut id de l'onglet cible -

<!-- Here the link is used to activates 1st tab, has the same href attribute (#tab1) as the id attribute of 1st tab (tab1)  -->
<a href = "#tab1" class = "tab-link active">Tab 1</a>

<!-- Here the link is used to activates 2st tab, has the same href attribute (#tab2) as the id attribute of 2st tab (tab2)  -->
<a href = "#tab2" class = "tab-link">Tab 2</a>

<a href = "#tab3" class = "tab-link">Tab 3</a>

Changer d'onglets multiples

Si vous utilisez un lien d'onglet unique pour basculer entre plusieurs onglets, vous pouvez utiliser des classes au lieu d'utiliser l' attribut d' ID et d' onglet de données .

<!-- For Top Tabs  -->
<div class = "tabs tabs-top">
   <div class = "tab tab1 active">...</div>
   <div class = "tab tab2">...</div>
   <div class = "tab tab3">...</div>
</div>

<!-- For Bottom Tabs -->
<div class = "tabs tabs-bottom">
   <div class = "tab tab1 active">...</div>
   <div class = "tab tab2">...</div>
   <div class = "tab tab3">...</div>
</div>

<!-- For Tabs links -->
<div class = "tab-links">
   <!-- Links are switch top and bottom tabs to .tab1 -->
   <a href = "#" class = "tab-link" data-tab = ".tab1">Tab 1</a>
   <!-- Links are switch top and bottom tabs to .tab2 -->
   <a href = "#" class = "tab-link" data-tab = ".tab2">Tab 2</a>
   <!-- Links are switch top and bottom tabs to .tab3 -->
   <a href = "#" class = "tab-link" data-tab = ".tab3">Tab 3</a>
</div>

L' attribut data-tab de tab-link contient le sélecteur CSS des onglets / onglets cibles.

Nous pouvons utiliser différentes manières d'onglets, celles-ci sont spécifiées dans le tableau suivant -

S.Non Types d'onglets et description
1 Onglets intégrés

Les onglets en ligne sont des ensembles groupés en ligne qui vous permettent de basculer rapidement entre eux.

2 Changer d'onglet depuis la barre de navigation

Nous pouvons placer des onglets dans la barre de navigation qui vous permettent de basculer entre eux.

3 Changer de vue depuis la barre d'onglets

Un seul onglet peut être utilisé pour basculer entre les vues avec sa propre navigation et mise en page.

4 Onglets animés

Vous pouvez utiliser une transition simple (animation) pour changer d'onglet.

5 Onglets à faire glisser

Vous pouvez créer des onglets à faire glisser avec une transition simple en utilisant la classe tabs-swipeable-wrap pour les onglets.

6 Onglets Événements JavaScript

Les événements JavaScript peuvent être utilisés lorsque vous travaillez avec du code JavaScript pour les onglets.

sept Afficher l'onglet à l'aide de JavaScript

Vous pouvez changer ou afficher l'onglet à l'aide de méthodes JavaScript.

La description

Le curseur de balayage est le curseur tactile le plus puissant et le plus moderne et entre dans Framework7 avec de nombreuses fonctionnalités.

La disposition HTML suivante montre le curseur de balayage -

<!-- Container class for slider -->
<div class = "swiper-container">
   <!-- Wrapper class for slider -->
   <div class = "swiper-wrapper">
      <!-- Slides -->
      <div class = "swiper-slide">Slide 1</div>
      <div class = "swiper-slide">Slide 2</div>
      <div class = "swiper-slide">Slide 3</div>
      ... other slides ...
   </div>
   
   <!-- Define pagination, if it is required -->
   <div class = "swiper-pagination"></div>
</div>

Les classes suivantes sont utilisées pour le curseur de balayage -

  • swiper-container - C'est un élément obligatoire pour le conteneur de curseur principal et il est utilisé pour les diapositives et les paginations.

  • Swiper-wrapper - Il s'agit d'un élément obligatoire pour les diapositives d'emballage supplémentaires.

  • swiper-slide - Il s'agit d'un élément de diapositive unique et il peut contenir n'importe quel HTML à l'intérieur.

  • swiper-pagination - Il est facultatif pour les puces de pagination et celles-ci sont créées automatiquement.

Vous pouvez initialiser le swiper avec JavaScript en utilisant ses méthodes associées -

myApp.swiper(swiperContainer,parameters)

OU

new Swiper(swiperContainer, parameters)

Les deux méthodes sont utilisées pour initialiser le curseur avec des options.

Les méthodes données ci-dessus contiennent les paramètres suivants -

  • swiperContainer- Il s'agit d'un HTMLElement ou d'une chaîne d'un conteneur de balayage et il est obligatoire.

  • parameters - Ce sont des éléments optionnels contenant un objet avec des paramètres de balayage.

Par exemple -

var mySwiper = app.swiper('.swiper-container', {
   speed: 400,
   spaceBetween: 100
});

Il est possible d'accéder à une instance de swiper et la propriété swiper du conteneur du slider a l'élément HTML suivant -

var mySwiper = $$('.swiper-container')[0].swiper;

// Here you can use all slider methods like:
mySwiper.slideNext();

Vous pouvez voir les différentes manières et types de swiper dans le tableau suivant -

S.Non Types de balayage et description
1 Balayeur par défaut avec pagination

Il s'agit d'un curseur tactile moderne et le balayage glisse horizontalement, par défaut.

2 Balayeur vertical

Celui-ci fonctionne également comme un swiper par défaut, mais il glisse verticalement.

3 Avec espace entre les diapositives

Ce swiper est utilisé pour laisser de l'espace entre deux diapositives.

4 Balais multiples

Ce swiper utilise plus d'un swipers sur une seule page.

5 Swipers imbriqués

C'est la combinaison de diapositives verticales et horizontales.

6 Contrôles personnalisés

Il est utilisé pour les contrôles personnalisés pour choisir ou faire glisser n'importe quelle diapositive.

sept Chargement paresseux

Il peut être utilisé pour un fichier multimédia, qui prend du temps à charger.

La description

Le navigateur de photos est similaire au composant de navigateur de photos iOS pour afficher un groupe d'images, qui peut être agrandi et panoramique. Pour glisser entre les images, le navigateur de photos utilise Swiper Slider .

Le tableau suivant montre les types de navigateur de photos utilisés dans framework7 -

S.Non Types de navigateur de photos et description
1 Créer une instance de navigateur de photos

Le navigateur de photos peut être créé et initialisé à l'aide de JavaScript uniquement.

2 Paramètres du navigateur de photos

Framework7 fournit une liste de paramètres, qui sont utilisés avec le navigateur de photos.

3 Méthodes et propriétés du navigateur de photos

Vous obtiendrez une variable d'instance initialisée pour utiliser les méthodes et les propriétés du navigateur de photos une fois que vous initialiserez le navigateur de photos.

4 Tableau de photos

Lors de l'initialisation du navigateur de photos, vous devez passer le tableau avec les photos / vidéos dans le paramètre photos .

5 Modèles de navigateur de photos

Framework7 vous fournit de nombreux modèles de navigateur photo, que vous pouvez transmettre lors de l'initialisation du navigateur photo.

La description

La saisie semi-automatique est un composant convivial et tactile de Framework7, qui peut être sous forme de liste déroulante ou de manière autonome. Vous pouvez créer et initialiser une instance de saisie semi-automatique à l'aide de la méthode JavaScript -

myApp.autocomplete(parameters)

Où les paramètres sont des objets obligatoires utilisés pour initialiser l'instance de saisie semi-automatique.

Paramètres de saisie semi-automatique

Le tableau suivant répertorie les paramètres de saisie semi-automatique disponibles dans Framework7 -

S.Non Paramètres et description Type Défaut
1

openIn

Il définit comment ouvrir une saisie semi-automatique qui pourrait être utilisée comme liste déroulante, popup ou page.

chaîne page
2

source

Il utilise une instance de saisie semi-automatique, une requête de recherche et une fonction de rendu pour transmettre les éléments correspondants avec un tableau.

fonction (saisie semi-automatique, requête, rendu) -
3

valueProperty

Il spécifie la valeur d'élément de la clé de l'objet élément correspondant.

chaîne id
4

limit

Il affiche le nombre limité d'éléments en saisie semi-automatique par requête.

nombre -
5

preloader

Preloader peut être utilisé pour spécifier la mise en page de saisie semi-automatique en le définissant sur true.

booléen faux
6

preloaderColor

Il spécifie la couleur du préchargeur. Par défaut, la couleur est "noir".

chaîne -
sept

value

Définit le tableau avec les valeurs sélectionnées par défaut.

tableau -
8

textProperty

Il spécifie la valeur d'élément de la clé d'objet d'élément correspondant, qui peut être utilisée comme titre des options affichées.

chaîne texte

Paramètres de saisie semi-automatique autonomes

Le tableau suivant répertorie les paramètres de saisie semi-automatique autonomes disponibles dans Framework7 -

S.Non Paramètres et description Type Défaut
1

opener

Il s'agit d'un paramètre de chaîne ou d'élément HTML qui ouvrira la page de saisie semi-automatique autonome.

chaîne ou HTMLElement -
2

popupCloseText

Il est utilisé pour fermer la fenêtre contextuelle de saisie semi-automatique.

chaîne 'Fermer'
3

backText

Il fournit le lien de retour lorsque la saisie semi-automatique est ouverte en tant que page.

chaîne 'Retour'
4

pageTitle

Il spécifie le titre de la page de saisie semi-automatique.

chaîne -
5

searchbarPlaceholderText

Il spécifie le texte de l'espace réservé de la barre de recherche.

chaîne 'Chercher'
6

searchbarCancelText

Il définit le texte du bouton d'annulation de la barre de recherche.

chaîne 'Annuler'
sept

notFoundText

Il affiche le texte lorsqu'il n'y a pas d'élément correspondant trouvé.

chaîne 'Rien n'a été trouvé'
8

multiple

Il permet de sélectionner plusieurs sélections en le définissant sur true.

booléen faux
9

navbarTheme

Il spécifie le thème de couleur pour la barre de navigation.

chaîne -
dix

backOnSelect

Lorsque l'utilisateur choisit une valeur, la saisie semi-automatique sera fermée en la définissant sur true.

booléen faux
11

formTheme

Il spécifie le thème de couleur du formulaire.

chaîne -

Paramètres de saisie semi-automatique de la liste déroulante

Le tableau suivant répertorie les paramètres de saisie semi-automatique de la liste déroulante disponibles dans Framework7 -

S.Non Paramètres et description Type Défaut
1

input

Il s'agit d'une chaîne ou d'un élément HTML utilisé pour la saisie de texte.

chaîne ou HTMLElement -
2

dropdownPlaceholderText

Il spécifie le texte de l'espace réservé de la liste déroulante.

chaîne -
3

updateInputValueOnSelect

Vous pouvez mettre à jour la valeur d'entrée lors de la sélection en la définissant sur true.

booléen vrai
4

expandInput

Vous pouvez développer la saisie de texte dans la vue Liste pour rendre le plein écran visible pendant la liste déroulante en définissant l'entrée d'élément sur true.

booléen faux

Fonctions de rappel automatique

Le tableau ci-dessous répertorie les paramètres de saisie semi-automatique de la liste déroulante disponibles dans Framework7 -

S.Non Paramètres et description Type Défaut
1

onChange

Chaque fois que la valeur de saisie semi-automatique est modifiée, cette fonction de rappel sera exécutée.

fonction (saisie semi-automatique, valeur) -
2

onOpen

Chaque fois que la saisie semi-automatique est ouverte, cette fonction de rappel sera exécutée.

fonction (saisie semi-automatique) -
3

onClose

Chaque fois que la saisie semi-automatique est fermée, cette fonction de rappel sera exécutée.

fonction (saisie semi-automatique) -

Modèles de saisie semi-automatique

Le tableau suivant répertorie les paramètres de saisie semi-automatique de la liste déroulante disponibles dans Framework7 -

S.Non Paramètres et description Type Défaut
1

navbarTemplate

Il s'agit d'un modèle de barre de navigation à saisie semi-automatique autonome.

chaîne -
2

itemTemplate

Il s'agit d'un élément de formulaire template7 autonome.

chaîne -
3

dropdownTemplate

C'est un modèle de liste déroulante template7.

chaîne -
4

dropdownItemTemplate

Il s'agit d'un élément de liste déroulante template7.

chaîne -
5

dropdownPlaceholderTemplate

Il s'agit de l'élément d'espace réservé de la liste déroulante template7.

chaîne -

Modèles par défaut

Voici les extraits de code de modèle par défaut pour les paramètres de modèles définis ci-dessus -

navbarTemplate

<div class = "navbar {{#if navbarTheme}}theme-{{navbarTheme}}{{/if}}">
   <div class = "navbar-inner">
      <div class = "left sliding">
         {{#if material}}
            <a href = "#" class = "link {{#if inPopup}}close-popup{{else}}back{{/if}} icon-only">
               <i class = "icon icon-back"></i>
            </a>
         {{else}}
            <a href = "#" class = "link {{#if inPopup}}close-popup{{else}}back{{/if}}">
               <i class = "icon icon-back"></i>
               {{#if inPopup}}
                  <span>{{popupCloseText}}</span>
               {{else}}
                  <span>{{backText}}</span>
               {{/if}}
            </a>
         {{/if}}
      </div>

      <div class = "center sliding">{{pageTitle}}</div>
      {{#if preloader}}
         <div class = "right">
            <div class = "autocomplete-preloader preloader 
               {{#if preloaderColor}}
                  preloader-{{preloaderColor}}
               {{/if}}">
            </div>
         </div>
      {{/if}}
   </div>
</div>

itemTemplate

<li>
    <label class = "label-{{inputType}} item-content">
        <input type = "{{inputType}}" name = "{{inputName}}" value = "{{value}}" {{#if selected}}checked{{/if}}>
        {{#if material}}
            <div class = "item-media">
                <i class = "icon icon-form-{{inputType}}"></i>
            </div>
            
            <div class = "item-inner">
                <div class = "item-title">{{text}}</div>
            </div>
        {{else}}
            {{#if checkbox}}
               <div class = "item-media">
                  <i class = "icon icon-form-checkbox"></i>
               </div>
            {{/if}}
            
            <div class = "item-inner">
                <div class = "item-title">{{text}}</div>
            </div>
        {{/if}}
    </label>
</li>

dropdownTemplate

<div class = "autocomplete-dropdown">
   <div class = "autocomplete-dropdown-inner">
      <div class = "list-block">
         <ul></ul>
      </div>
   </div>
   
   {{#if preloader}}
      <div class = "autocomplete-preloader preloader 
         {{#if preloaderColor}}
            preloader-{{preloaderColor}}
         {{/if}}">
         {{#if material}}
            {{materialPreloaderHtml}}
         {{/if}}
      </div>
   {{/if}}
</div>

dropdownItemTemplate

<li>
   <label class = "{{#unless placeholder}}label-radio{{/unless}} item-content" data-value = "{{value}}">
      <div class = "item-inner">
         <div class = "item-title">{{text}}</div>
      </div>
   </label>
</li>

dropdownPlaceholderTemplate

<li class = "autocomplete-dropdown-placeholder">
   <div class = "item-content">
      <div class = "item-inner">
         <div class = "item-title">{{text}}</div>
      </div>
   </label>
</li>

Méthodes de saisie semi-automatique

Le tableau suivant spécifie les méthodes de saisie semi-automatique disponibles dans Framework7 -

S.Non Méthodes et description
1

myAutocomplete.params

Définit les paramètres d'initialisation qui sont passés avec l'objet.

2

myAutocomplete.value

Il définit le tableau avec les valeurs sélectionnées.

3

myAutocomplete.opened

Il ouvre la saisie semi-automatique si elle est définie sur true.

4

myAutocomplete.dropdown

Il spécifie une instance de liste déroulante de saisie semi-automatique.

5

myAutocomplete.popup

Il spécifie une instance de popup de saisie semi-automatique.

6

myAutocomplete.page

Il spécifie une instance de la page de saisie semi-automatique.

sept

myAutocomplete.pageData

Il définit les données de la page de saisie semi-automatique.

8

myAutocomplete.searchbar

Il définit l'instance de la barre de recherche de saisie semi-automatique.

Propriétés de saisie semi-automatique

Le tableau suivant spécifie les méthodes de saisie semi-automatique disponibles dans Framework7 -

S.Non Propriétés et description
1

myAutocomplete.open()

Il ouvre la saisie semi-automatique, qui peut être utilisée comme liste déroulante, popup ou page.

2

myAutocomplete.close()

Il ferme la saisie semi-automatique.

3

myAutocomplete.showPreloader()

Il montre le préchargeur de saisie semi-automatique.

4

myAutocomplete.hidePreloader()

Il masque le préchargeur de saisie semi-automatique.

5

myAutocomplete.destroy()

Il ruine l'instance de préchargement de saisie semi-automatique et supprime tous les événements.

Exemple

L'exemple suivant montre l'utilisation de paramètres de saisie semi-automatique masqués dans le Framework7 -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Autocomplete</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
            <div class = "pages">
               <div data-page = "home" class = "page navbar-fixed">
               
                  <div class = "navbar">
                     <div class = "navbar-inner">
                        <div class = "left"> </div>
                        <div class = "center">Autcomplete</div>
                        <div class = "right"> </div>
                     </div>
                  </div>
               
                  <div class = "page-content">
                     <div class = "content-block-title">Simple Dropdown Autocomplete</div>
                     <div class = "list-block">
                        <ul>
                           <li class = "item-content">
                              <div class = "item-title label">Country</div>
                              <div class = "item-input">
                                 <input type = "text" placeholder = "Country" id = "autocomplete-dropdown">
                              </div>
                           </li>
                        </ul>
                     </div>
                  
                     <div class = "content-block-title">Dropdown With Input Expand</div>
                     <div class = "list-block">
                        <ul>
                           <li class = "item-content">
                              <div class = "item-title label">Country</div>
                              <div class = "item-input">
                                 <input type = "text" placeholder = "Country" id = "autocomplete-dropdown-expand">
                              </div>
                           </li>
                        </ul>
                     </div>
                  
                     <div class = "content-block-title">Dropdown With All Values</div>
                     <div class = "list-block">
                        <ul>
                           <li class = "item-content">
                              <div class = "item-title label">Country</div>
                              <div class = "item-input">
                                 <input type = "text" placeholder = "Country" id = "autocomplete-dropdown-all">
                              </div>
                           </li>
                        </ul>
                     </div>
                  
                     <div class = "content-block-title">Dropdown With Placeholder</div>
                     <div class = "list-block">
                        <ul>
                           <li class = "item-content">
                              <div class = "item-title label">Country</div>
                              <div class = "item-input">
                                 <input type = "text" placeholder = "Country" id = "autocomplete-dropdown-placeholder">
                              </div>
                           </li>
                        </ul>
                     </div>
                  
                     <div class = "content-block-title">Simple Standalone Autocomplete</div>
                     <div class = "list-block">
                        <ul>
                           <li>
                              <a href = "#" id = "autocomplete-standalone" class = "item-link item-content autocomplete-opener">
                                 <input type = "hidden">
                                 <div class = "item-inner">
                                    <div class = "item-title">Favorite Country</div>
                                    <div class = "item-after"></div>
                                 </div>
                              </a>
                           </li>
                        </ul>
                     </div>
                  
                     <div class = "content-block-title">Popup Standalone Autocomplete</div>
                     <div class = "list-block">
                        <ul>
                           <li>
                              <a href = "#" id = "autocomplete-standalone-popup" class = "item-link item-content autocomplete-opener">
                                 <input type = "hidden">
                                 <div class = "item-inner">
                                    <div class = "item-title">Favorite Country</div>
                                    <div class = "item-after"></div>
                                 </div>
                              </a>
                           </li>
                        </ul>
                     </div>
                  
                     <div class = "content-block-title">Multiple Values Standalone Autocomplete</div>
                     <div class = "list-block">
                        <ul>
                           <li>
                              <a href = "#" id = "autocomplete-standalone-multiple" class = "item-link item-content autocomplete-opener">
                                 <input type = "hidden">
                                 <div class = "item-inner">
                                    <div class = "item-title">Favorite Countries</div>
                                    <div class = "item-after"></div>
                                 </div>
                              </a>
                           </li>
                        </ul>
                     </div>
                  </div> 
                  
               </div>
            </div>
         </div>
      </div>
      
      <script type  =  "text/javascript" 
         src  =  "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
         
      <script>
         var myApp  =  new Framework7();
         var $$  =  Dom7;
         var mainView  =  myApp.addView('.view-main');
         
         // Countries data array
         var countries  =  ('India Africa Australia NewZealand England WestIndies Scotland Zimbabwe Srilanka Bangladesh').split(' ');

         // Simple Dropdown
         var autocompleteDropdownSimple  =  myApp.autocomplete ({
            input: '#autocomplete-dropdown',
            openIn: 'dropdown',
            
            source: function (autocomplete, query, render) {
               var results  =  [];
               if (query.length === 0) {
                  render(results);
                  return;
               }
               
               // You can find matched items
               for (var i = 0; i < countries.length; i++) {
                  if (countries[i].toLowerCase().indexOf(query.toLowerCase()) >= 0) 
                     results.push(countries[i]);
               }
               // Display the items by passing array with result items
               render(results);
            }
         });

         // Dropdown with input expand
         var autocompleteDropdownExpand = myApp.autocomplete ({
            input: '#autocomplete-dropdown-expand',
            openIn: 'dropdown',
            expandInput: true,   // expandInput used as item-input in List View will be expanded to full screen wide
                                 //during dropdown
            source: function (autocomplete, query, render) {
               var results = [];
               if (query.length === 0) {
                  render(results);
                  return;
               }
               // Find matched items
               for (var i = 0; i < countries.length; i++) {
                  if (countries[i].toLowerCase().indexOf(query.toLowerCase()) >= 0) results.push(countries[i]);
               }
               // Display the items by passing array with result items
               render(results);
            }
         });

         // Dropdown with all values
         var autocompleteDropdownAll = myApp.autocomplete ({
            input: '#autocomplete-dropdown-all',
            openIn: 'dropdown',
            
            source: function (autocomplete, query, render) {
               var results = [];
               
               // You can find matched items
               for (var i = 0; i < countries.length; i++) {
                  if (countries[i].toLowerCase().indexOf(query.toLowerCase()) >= 0) 
                     results.push(countries[i]);
               }
               // Display the items by passing array with result items
               render(results);
            }
         });

         // Dropdown with placeholder
         var autocompleteDropdownPlaceholder = myApp.autocomplete ({
            input: '#autocomplete-dropdown-placeholder',
            openIn: 'dropdown',
            dropdownPlaceholderText: 'Type as "India"',
            source: function (autocomplete, query, render) {
               var results = [];
               if (query.length === 0) {
                  render(results);
                  return;
               }
               
               // You can find matched items
               for (var i = 0; i < countries.length; i++) {
                  if (countries[i].toLowerCase().indexOf(query.toLowerCase()) >= 0) 
                     results.push(countries[i]);
               }
                  
               // Display the items by passing array with result items
               render(results);
            }
         });

         // Simple Standalone
         var autocompleteStandaloneSimple = myApp.autocomplete ({
            openIn: 'page', //open in page
            opener: $$('#autocomplete-standalone'), //link that opens autocomplete
            backOnSelect: true, //go back after we select something
            
            source: function (autocomplete, query, render) {
               var results = [];
               if (query.length === 0) {
                  render(results);
                  return;
               }
               
               // You can find matched items
               for (var i = 0; i < countries.length; i++) {
                  if (countries[i].toLowerCase().indexOf(query.toLowerCase()) >= 0) 
                     results.push(countries[i]);
               }
               // Display the items by passing array with result items
               render(results);
            },
               
            onChange: function (autocomplete, value) {
               // Here add the item text value to item-after
               $$('#autocomplete-standalone').find('.item-after').text(value[0]);
               
               // You can add item value to input value
               $$('#autocomplete-standalone').find('input').val(value[0]);
            }
         });

         // Standalone Popup
         var autocompleteStandalonePopup = myApp.autocomplete ({
            openIn: 'popup', // Opens the Autocomplete in page
            opener: $$('#autocomplete-standalone-popup'), // It will open standalone autocomplete popup
            backOnSelect: true, //After selecting item, then go back to page
            source: function (autocomplete, query, render) {
            var results = [];
            if (query.length === 0) {
               render(results);
               return;
            }
            
            // You can find matched items
            for (var i = 0; i < countries.length; i++) {
               if (countries[i].toLowerCase().indexOf(query.toLowerCase()) >= 0) results.push(countries[i]);
            }
            
            // Display the items by passing array with result items
               render(results);
            },
            
            onChange: function (autocomplete, value) {
               // Here add the item text value to item-after
               $$('#autocomplete-standalone-popup').find('.item-after').text(value[0]);
               
               // You can add item value to input value
               $$('#autocomplete-standalone-popup').find('input').val(value[0]);
            }
         });

         // Multiple Standalone
         var autocompleteStandaloneMultiple = myApp.autocomplete ({
            openIn: 'page', //Opens the Autocomplete in page
            opener: $$('#autocomplete-standalone-multiple'), //link that opens autocomplete
            multiple: true, //Allow multiple values
            source: function (autocomplete, query, render) {
               var results = [];
               if (query.length === 0) {
                  render(results);
                  return;
               }
               
               // You can find matched items
               for (var i = 0; i < countries.length; i++) {
                  if (countries[i].toLowerCase().indexOf(query.toLowerCase()) >= 0) results.push(countries[i]);
               }
               
               // Display the items by passing array with result items
               render(results);
            },
            
            onChange: function (autocomplete, value) {
               // Here add the item text value to item-after
               $$('#autocomplete-standalone-multiple').find('.item-after').text(value.join(', '));
               
               // You can add item value to input value
               $$('#autocomplete-standalone-multiple').find('input').val(value.join(', '));
            }
         });
      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous autocomplete.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/autocomplete.html et la sortie s'affiche comme indiqué ci-dessous.

  • L'exemple fournit la saisie semi-automatique des valeurs dans une liste déroulante simple, une liste déroulante avec toutes les valeurs, une liste déroulante avec un espace réservé, une saisie semi-automatique autonome, etc.

La description

Le sélecteur ressemble au sélecteur natif iOS et il s'agit d'un composant puissant qui vous permet de sélectionner toutes les valeurs de la liste et également utilisé pour créer des sélecteurs de superposition personnalisés. Vous pouvez utiliser le sélecteur comme composant en ligne ou comme superposition. Le sélecteur de superposition sera automatiquement converti en Popover sur les tablettes (iPad).

En utilisant la méthode de l'application suivante, vous pouvez créer et initialiser la méthode JavaScript -

myApp.picker(parameters)

Où les paramètres sont des objets obligatoires, utilisés pour initialiser l'instance de sélecteur et c'est une méthode obligatoire.

Paramètres du sélecteur

Le tableau suivant spécifie les paramètres disponibles dans les sélecteurs -

S.Non Paramètres et description Type Défaut
1

container

Chaîne avec sélecteur CSS ou HTMLElement utilisée pour générer le code HTML du sélecteur pour un sélecteur en ligne.

chaîne ou HTMLElement -
2

input

L'élément d'entrée associé placé avec la chaîne avec le sélecteur CSS ou HTMLElement.

chaîne ou HTMLElement -
3

scrollToInput

Il est utilisé pour faire défiler la fenêtre (contenu de la page) de l'entrée, chaque fois que le sélecteur est ouvert.

booléen vrai
4

inputReadOnly

Utilisé pour définir l'attribut "lecture seule" sur l'entrée spécifiée.

booléen vrai
5

convertToPopover

Il est utilisé pour convertir le sélecteur modal en Popover sur de grands écrans comme l'iPad.

booléen vrai
6

onlyOnPopover

Vous pouvez ouvrir le sélecteur dans Popover en l'activant.

booléen vrai
sept

cssClass

Pour sélectionner modal, vous pouvez utiliser un nom de classe CSS supplémentaire.

chaîne -
8

closeByOutsideClick

Vous pouvez fermer le sélecteur en cliquant à l'extérieur du sélecteur ou de l'élément d'entrée en activant la méthode.

booléen faux
9

toolbar

Il est utilisé pour activer la barre d'outils modale du sélecteur.

booléen vrai
dix

toolbarCloseText

Utilisé pour le bouton de la barre d'outils Terminé / Fermer.

chaîne 'Terminé'
11

toolbarTemplate

C'est un modèle HTML de barre d'outils, par défaut c'est une chaîne HTML avec le modèle suivant -

<div class = "toolbar">
  <div class = "toolbar-inner">
    <div class = "left"></div>
    <div class = "right">
      <a href = "#" class = "link close-picker">
         {{closeText}}
      </a>
    </div>
  </div>
</div>
chaîne -

Paramètres de sélecteur spécifiques

Le tableau suivant répertorie les paramètres de sélecteur spécifiques disponibles -

S.Non Paramètres et description Type Défaut
1

rotateEffect

Il active l'effet de rotation 3D dans le sélecteur.

booléen faux
2

momentumRatio

Lorsque vous relâchez le sélecteur après un toucher et un mouvement rapides, cela produit plus d'élan.

nombre sept
3

updateValuesOnMomentum

Utilisé pour mettre à jour les sélecteurs et saisir les valeurs pendant l'élan.

booléen faux
4

updateValuesOnTouchmove

Utilisé pour mettre à jour les sélecteurs et saisir les valeurs pendant le déplacement tactile.

booléen vrai
5

value

Le tableau a ses valeurs initiales et chaque élément du tableau représente la valeur de la colonne associée.

tableau -
6

formatValue

La fonction est utilisée pour formater la valeur d'entrée et elle doit renvoyer une nouvelle valeur de chaîne formatée. Les valeurs et displayValues sont un tableau de colonnes associées.

function (p, valeurs, displayValues) -
sept

cols

Chaque élément du tableau représente un objet avec des paramètres de colonne.

tableau -

Rappels de paramètres de sélecteur

Le tableau suivant présente les listes des fonctions de rappel disponibles dans les sélecteurs -

S.Non Rappels et description Type Défaut
1

onChange

La fonction de rappel sera exécutée chaque fois que la valeur du sélecteur a changé et les valeurs et displayValues sont des tableaux de colonnes associées.

function (p, valeurs, displayValues) -
2

onOpen

La fonction de rappel sera exécutée chaque fois que le sélecteur est ouvert.

fonction (p) -
3

onClose

La fonction de rappel sera exécutée chaque fois que le sélecteur est fermé.

fonction (p) -

Paramètres de colonne

Au moment de la configuration de Picker, nous devons passer le paramètre cols . Il est représenté sous forme de tableau, où chaque élément est un objet avec des paramètres de colonne -

S.Non Paramètres et description Type Défaut
1

values

Vous pouvez spécifier les valeurs des colonnes de chaîne avec un tableau.

tableau -
2

displayValues

Il a un tableau avec des valeurs de colonnes de chaîne et il affichera la valeur du paramètre values , lorsqu'il n'est pas spécifié.

tableau -
3

cssClass

Le nom de classe CSS utilisé pour définir sur le conteneur HTML de la colonne.

chaîne -
4

textAlign

Il est utilisé pour définir l'alignement du texte des valeurs de colonne et il peut être «gauche», «centre» ou «droite» .

chaîne -
5

width

La largeur est calculée automatiquement, par défaut. Si vous devez corriger les largeurs de colonne dans le sélecteur avec des colonnes dépendantes qui doivent être en px .

nombre -
6

divider

Il est utilisé pour la colonne qui doit être un diviseur visuel, il n'a aucune valeur.

booléen faux
sept

content

Il est utilisé pour spécifier la colonne de séparation (diviseur: vrai) avec le contenu de la colonne.

chaîne -

Paramètre des rappels de colonne

S.Non Rappels et description Type Défaut
1

onChange

Chaque fois que la valeur de la colonne changera, la fonction de rappel s'exécutera. La valeur et displayValue représentent la valeur actuelle de la colonne et displayValue .

function (p, value, displayValue) -

Propriétés du sélecteur

La variable Picker a de nombreuses propriétés qui sont données dans le tableau suivant -

S.Non Propriétés et description
1

myPicker.params

Vous pouvez initialiser les paramètres passés avec object.

2

myPicker.value

La valeur sélectionnée pour chaque colonne est représentée par un tableau d'éléments.

3

myPicker.displayValue

La valeur d'affichage sélectionnée pour chaque colonne est représentée par un tableau d'éléments.

4

myPicker.opened

Lorsque le sélecteur est ouvert, il prend la valeur vraie .

5

myPicker.inline

Lorsque le sélecteur est en ligne, il prend la valeur vraie .

6

myPicker.cols

Les colonnes Picker ont leurs propres méthodes et propriétés.

sept

myPicker.container

L'instance Dom7 est utilisée pour le conteneur HTML.

Méthodes de sélection

La variable de sélection a des méthodes utiles, qui sont données dans le tableau suivant -

S.Non Méthodes et description
1

myPicker.setValue(values, duration)

Utilisez pour définir une nouvelle valeur de sélecteur. Les valeurs sont dans un tableau où chaque élément représente la valeur de chaque colonne. duration - C'est la durée de transition en ms.

2

myPicker.open()

Utilisez pour ouvrir Picker.

3

myPicker.close()

Utilisez pour fermer Picker.

4

myPicker.destroy()

Utilisez pour détruire l'instance de Picker et supprimer tous les événements.

Propriétés de la colonne

Chaque colonne du tableau myPicker.cols a également ses propres propriétés utiles, qui sont données dans le tableau suivant -

//Get first column
var col = myPicker.cols[0];
S.Non Propriétés et description
1

col.container

Vous pouvez créer une instance avec un conteneur HTML de colonne.

2

col.items

Vous pouvez créer une instance avec des éléments HTML d'éléments de colonne.

3

col.value

Utilisé pour sélectionner la valeur actuelle de la colonne.

4

col.displayValue

Utilisé pour sélectionner la valeur actuelle de la colonne d'affichage.

5

col.activeIndex

Indiquez le numéro d'index actuel, qui est l'élément sélectionné / actif.

Méthodes de colonne

Les méthodes de colonne utiles sont données dans le tableau suivant -

S.Non Méthodes et description
1

col.setValue(value, duration)

Utilisé pour définir une nouvelle valeur pour la colonne actuelle. La valeur doit être une nouvelle valeur et la durée est la durée de transition exprimée en ms.

2

col.replaceValues(values, displayValues)

Utilisé pour remplacer les valeurs de colonne et displayValues ​​par de nouvelles.

Il est utilisé pour accéder à l'instance de Picker à partir de son conteneur HTML, chaque fois que vous initialisez Picker en tant que Picker en ligne.

var myPicker = $$('.picker-inline')[0].f7Picker;

Il existe différents types de sélecteurs tels que spécifiés dans le tableau suivant -

S.Non Types d'onglets et description
1 Sélecteur à valeur unique

C'est un composant puissant qui vous permet de choisir toutes les valeurs de la liste.

2 Deux valeurs et effet de rotation 3D

Dans le sélecteur, vous pouvez utiliser pour l'effet de rotation 3D.

3 Valeurs dépendantes

Les valeurs dépendent les unes des autres pour l'élément spécifié.

4 Barre d'outils personnalisée

Vous pouvez utiliser un ou plusieurs sélecteurs sur une seule page pour le personnaliser.

5 Sélecteur en ligne / Date-heure

Vous pouvez sélectionner le nombre de valeurs dans le sélecteur en ligne. Comme la date a la date, le mois, l'année et l'heure a les heures, les minutes, les secondes.

La description

Le composant Calendrier vous permet de gérer facilement les dates et peut être utilisé en tant que composant en ligne ou en superposition. Le calendrier de superposition sera automatiquement converti en popover sur les tablettes.

Le calendrier peut être créé et initialisé uniquement à l'aide de JavaScript. Vous devez utiliser la méthode de l'application associée comme indiqué ci-dessous -

  • myApp.calendar(parameters)- Cette méthode renvoie une instance de calendrier initialisée. Il accepte un objet comme paramètre.

Le tableau suivant montre l'utilisation du calendrier dans Framework7 -

S.Non Utilisation et description du calendrier
1 Paramètres du calendrier

Framework7 fournit une liste de paramètres, qui sont utilisés avec le calendrier.

2 Méthodes et propriétés du calendrier

Vous obtiendrez une variable d'instance initialisée pour utiliser les méthodes et propriétés du calendrier, une fois que vous initialiserez le calendrier.

3 Accès à l'instance du calendrier

Il est possible d'accéder à l'instance de calendrier à partir de son conteneur HTML lorsque vous initialisez le calendrier en ligne.

La description

C'est un composant spécial utilisé pour actualiser (recharger) le contenu de la page en le tirant.

Le code suivant montre comment actualiser le contenu de la page -

<div class = "page">
   <!-- Page content should have additional "pull-to-refresh-content" class -->
   <div class = "page-content pull-to-refresh-content" data-ptr-distance = "55">
      <!-- Default pull to refresh layer-->
      <div class = "pull-to-refresh-layer">
         <div class = "preloader"></div>
      <div class = "pull-to-refresh-arrow"></div>
   </div>

   <!-- usual content below -->
   <div class = "list-block">
      ...
   </div>
</div>

Les classes suivantes sont utilisées pour l’actualisation -

  • page-content- Il a une classe supplémentaire de contenu pull-to-refresh-content et est nécessaire pour activer pull pour actualiser.

  • pull-to-refresh-layer- C'est un calque caché, qui est utilisé pour tirer pour rafraîchir l'élément visuel et ce n'est qu'un préchargement et une flèche.

  • data-ptr-distance = "55" - Il s'agit d'un attribut supplémentaire qui vous permet de définir une distance de déclenchement personnalisée «tirer pour actualiser» et sa valeur par défaut est 44px.

Tirer pour actualiser les événements

Dans 'Pull to Refresh', il y a quelques événements JavaScript, qui sont donnés dans le tableau suivant -

S.Non Description de l'évenement Cible
1

pullstart

Il sera déclenché chaque fois que vous commencerez à tirer pour actualiser le contenu.

Tirez pour actualiser le contenu.

<div class = "pull-to-refresh-content">
2

pullmove

Il est déclenché lorsque vous tirez pour actualiser le contenu.

Tirez pour actualiser le contenu.

<div class="pull-to-refresh-content">
3

pullend

Il sera déclenché chaque fois que vous relâchez pull pour actualiser le contenu.

Tirez pour actualiser le contenu.

<div class="pull-to-refresh-content">
4

refresh

Cet événement sera déclenché lorsque le pull pour rafraîchir entre dans l'état «rafraîchissement» .

Tirez pour actualiser le contenu.

<div class="pull-to-refresh-content">
5

refreshdone

Il sera déclenché après avoir été actualisé et il reviendra à l'état initial. Cela sera fait après l'appel de la méthode pullToRefreshDone .

Tirez pour actualiser le contenu.

<div class="pull-to-refresh-content">

Il existe des méthodes d'application qui peuvent être utilisées avec Pull to Refresh.

S.Non Méthodes et description de l'application
1

myApp.pullToRefreshDone(ptrContent)

Il est utilisé pour réinitialiser le contenu pull-to-refresh .

2

myApp.pullToRefreshTrigger(ptrContent)

Il est utilisé pour déclencher l'actualisation lors de l' extraction spécifiée pour actualiser le contenu .

3

myApp.destroyPullToRefresh(ptrContent)

Il est utilisé pour détruire / désactiver pull pour actualiser sur pull spécifié pour actualiser le contenu .

4

myApp.initPullToRefresh(ptrContent)

Il est utilisé pour initialiser / activer pull pour actualiser le contenu .

ptrContent est utilisé pour HTMLElement ou une chaîne pour extraire du contenu d'actualisation pour réinitialiser / déclencher ou désactiver / activer.

Exemple

L'exemple suivant illustre l'utilisation du composant d'actualisation qui lance l'actualisation du contenu d'une page -

<!DOCTYPE html>
<html>
   <head>
      <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no, minimal-ui">
      <meta name="apple-mobile-web-app-capable" content="yes">
      <meta name="apple-mobile-web-app-status-bar-style" content="black">
      <title>Pull To Refresh</title>
      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css">
      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css">
   </head>
   <div class="views">
      <div class="view view-main">
         <div class="pages">
            <div data-page="home" class="page navbar-fixed">
               <div class="navbar">
                  <div class="navbar-inner">
                     <div class="left"> </div>
                     <div class="center">Pull To Refresh</div>
                     <div class="right"> </div>
                  </div>
               </div>
               <div class="page-content pull-to-refresh-content">
                  <div class="pull-to-refresh-layer">
                     <div class="preloader"></div>
                     <div class="pull-to-refresh-arrow"></div>
                  </div>
                  <div class="list-block media-list">
                     <ul>
                        <li class="item-content">
                           <div class="item-media"><img src="/framework7/images/apple.png" width="44"></div>
                           <div class="item-inner">
                              <div class="item-title-row">
                                 <div class="item-title">apple</div>
                              </div>
                           </div>
                        </li>
                        <li class="item-content">
                           <div class="item-media"><img src="/framework7/images/froots_img.jpg" width="44"></div>
                           <div class="item-inner">
                              <div class="item-title-row">
                                 <div class="item-title">strawberry</div>
                              </div>
                           </div>
                        </li>
                        <li class="item-content">
                           <div class="item-media"><img src="/framework7/images/mango.jpg" width="44"></div>
                           <div class="item-inner">
                              <div class="item-title-row">
                                 <div class="item-title">Mango</div>
                              </div>
                           </div>
                        </li>
                     </ul>
                     <div class="list-block-label">
                        <p>Just pull page down to let the magic happen.</p>
                     </div>
                  </div>
               </div>
            </div>
         </div>
      </div>
   </div>
   <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
   <script>
      var myApp = new Framework7();

      var $$ = Dom7;

      // Dummy Content
      var fruits = ['mango', 'orange', 'watermelon', 'banana'];
      // Pull to refresh content
      var ptrContent = $$('.pull-to-refresh-content');
      // Add 'refresh' listener on it
      ptrContent.on('refresh', function (e) {
         // Emulate 2s loading
         setTimeout(function () {
            var picURL = 'images/Fruit.jpg' + Math.round(Math.random() * 100);
            var fruit = fruits[Math.floor(Math.random() * fruits.length)];
            var itemHTML = '<li class="item-content">' +
               '<div class="item-media"><img src="/framework7/images/Fruit.jpg" width="44"/></div>' +
               '<div class="item-inner">' +
               '<div class="item-title-row">' +
               '<div class="item-title">' + fruit + '</div>' +
                  '</div>' + '</div>' + '</li>';
            // Prepend new list element
            ptrContent.find('ul').prepend(itemHTML);
				
            // When loading done, we need to reset it
            myApp.pullToRefreshDone();
         }, 2000);
      });
   </script>
</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous pull_to_refresh.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/pull_to_refresh.html et la sortie s'affiche comme indiqué ci-dessous.

  • Lorsque l'utilisateur descend, la page est actualisée avec le contenu.

La description

Le défilement infini vous permet de charger du contenu supplémentaire et effectue les actions requises lorsque la page est proche du bas.

La mise en page HTML suivante montre le défilement infini -

<div class = "page">
   <div class = "page-content infinite-scroll" data-distance = "100">
      ...
   </div>
</div>

La disposition ci-dessus contient les classes suivantes -

  • page-content infinite-scroll - Il est utilisé pour le conteneur de défilement infini.

  • data-distance - Cet attribut vous permet de configurer la distance depuis le bas de la page (en px) pour déclencher un événement de défilement infini et sa valeur par défaut est 50px.

Si vous souhaitez utiliser le défilement infini en haut de la page, vous devez ajouter une classe supplémentaire "infinite-scroll-top" à "page-content" -

<div class = "page">
   <div class = "page-content infinite-scroll infinite-scroll-top">
      ...
   </div>
</div>

Événements de défilement infini

infinite- Il est utilisé pour déclencher lorsque le défilement de la page atteint la distance spécifiée vers le bas. Il sera ciblé par div class = "page-content infinite-scroll" .

Il existe deux méthodes d'application qui peuvent être utilisées avec un conteneur de défilement infini -

Pour ajouter un écouteur d'événement à défilement infini au conteneur HTML spécifié, utilisez la méthode suivante -

myApp.attachInfiniteScroll(container)

Vous pouvez supprimer l'écouteur d'événements de défilement infini du conteneur HTML spécifié à l'aide de la méthode suivante -

myApp.detachInfiniteScroll(container)

Où les paramètres sont obligatoires options utilisées comme HTMLElement ou chaîne pour le conteneur de défilement infini.

Exemple

L'exemple suivant illustre le défilement infini qui charge le contenu supplémentaire lorsque le défilement de la page est proche du bas -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name="apple-mobile-web-app-capable" content="yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>infinite_scroll</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>
   
   <body>
      <div class = "views">
         <div class = "view view-main">
         
            <div class = "navbar">
               <div class = "navbar-inner">
                  <div class = "left"> </div>
                  <div class = "center sliding">Infinite Scroll</div>
                  <div class = "right"> </div>
               </div>
            </div>
         
            <div class = "pages navbar-through">
               <div data-page = "home" class = "page">
                  <div class = "page-content infinite-scroll">
                     <div class = "list-block">
                        <ul>
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 1</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 2</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 3</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 4</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 5</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 6</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 7</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 8</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 9</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 10</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 11</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 12</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 13</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 14</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 15</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 16</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 17</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 18</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 19</div>
                              </div>
                           </li>
                        
                           <li class = "item-content">
                              <div class = "item-inner">
                                 <div class = "item-title">Item 20</div>
                              </div>
                           </li>
                        </ul>
                     </div>
                  
                     <div class = "infinite-scroll-preloader">
                        <div class = "preloader"></div>
                     </div>
                  </div>
               </div>
            </div>
         
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
         
      <style>
         .infinite-scroll-preloader {
            margin-top:-20px;
            margin-bottom:10px;
            text-align:center;
         }
         
         .infinite-scroll-preloader .preloader {
            width:34px;
            height:34px;
         }
      </style>
      
      <script>
         var myApp = new Framework7();
         var $$ = Dom7;

         // Loading flag
         var loading = false;

         // Last loaded index
         var lastIndex = $$('.list-block li').length;

         // Max items to load
         var maxItems = 60;

         // Append items per load
         var itemsPerLoad = 20;

         // Attach 'infinite' event handler
         $$('.infinite-scroll').on('infinite', function () {

            // Exit, if loading in progress
            if (loading) return;

            // Set loading flag
            loading = true;

            // Emulate 1s loading
            setTimeout(function () {
               // Reset loading flag
               loading = false;

               if (lastIndex >= maxItems) {
                  // Nothing more to load, detach infinite scroll events to prevent unnecessary loadings
                  myApp.detachInfiniteScroll($$('.infinite-scroll'));
                  
                  // Remove preloader
                  $$('.infinite-scroll-preloader').remove();
                  return;
               }

               // Generate new items HTML
               var html = '';
               for (var i = lastIndex + 1; i <= lastIndex + itemsPerLoad; i++) {
                  html += '<li class = "item-content">
                     <div class = "item-inner">
                        <div class = "item-title">
                           Item ' + i + '
                        </div>
                     </div>
                  </li>';
               }

               // Append new items
               $$('.list-block ul').append(html);

               // Update last loaded index
               lastIndex = $$('.list-block li').length;
            }, 1000);
         });
      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous infinite_scroll.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/infinite_scroll.html et la sortie s'affiche comme indiqué ci-dessous.

  • L'exemple permet de charger du contenu supplémentaire lorsque le défilement de votre page atteint la distance spécifiée vers le bas.

La description

Les messages sont un composant de Framework7, qui permet de visualiser les commentaires et le système de messagerie dans l'application.

Disposition des messages

Le framework7 a la structure de disposition des messages suivante -

<div class = "page">
<div class = "page-content messages-content">
   <div class = "messages">
      <!-- Defines the date stamp -->
      <div class = "messages-date">Monday, Apr 26 <span>10:30</span></div>
      
      <!-- Displays the sent message and by default, it will be in green color on right side -->
      <div class = "message message-sent">
         <!-- Define the text with bubble type -->
         <div class = "message-text">Hello</div>
      </div>
      
      <!-- Displays the another sent message -->
      <div class = "message message-sent">
         <!-- Define the text with bubble type -->
         <div class = "message-text">How are you?</div>
      </div>
      
      <!-- Displays the received message and by default, it will be in grey color on left side -->
      <div class = "message message-with-avatar message-received">
         <!-- Provides sender name -->
         <div class = "message-name">Smith</div>
         <!--  Define the text with bubble type -->
         <div class = "message-text">I am fine, thanks</div>
         <!-- Defines the another date stamp -->
         <div class = "messages-date">Tuesday, April 28 <span>11:16</span></div>
      </div>
      
   </div>
</div>

La mise en page contient les classes suivantes dans différents domaines -

Mise en page des messages

Le tableau suivant présente les classes de mise en page de messages avec une description.

S.Non Classes et description
1

messages-content

C'est une classe supplémentaire obligatoire ajoutée à "page-content" et utilisée pour le wrapper de messages.

2

messages

C'est un élément obligatoire pour les bulles de messages.

3

messages-date

Il utilise le conteneur d'horodatage pour afficher la date et l'heure du message envoyé ou reçu.

4

message

C'est un message unique à afficher.

Pièces internes à message unique

Le tableau suivant montre les classes des parties internes de messages simples avec une description.

S.Non Classes et description
1

message-name

Il fournit le nom de l'expéditeur.

2

message-text

Définissez le texte avec le type de bulle.

3

message-avatar

Il spécifie l'avatar de l'expéditeur.

4

message-label

Il spécifie l'étiquette de texte sous la bulle.

Classes supplémentaires pour le conteneur de message unique

Le tableau suivant présente des classes supplémentaires pour la description de conteneur de message unique.

S.Non Classes et description
1

message-sent

Il spécifie que le message a été envoyé par l'utilisateur et est affiché avec une couleur d'arrière-plan verte sur le côté droit.

2

message-received

Il est utilisé pour afficher le message unique indiquant que le message a été reçu par l'utilisateur et reste sur le côté gauche avec une couleur de fond grise.

3

message-pic

C'est une classe supplémentaire pour afficher une image avec un seul message.

4

message-with-avatar

C'est une classe supplémentaire pour afficher un seul message (reçu ou envoyé) avec un avatar.

5

message-with-tail

Vous pouvez ajouter une queue de bulle pour un seul message (reçu ou envoyé).

Classes supplémentaires disponibles pour un message unique

Le tableau suivant montre les classes disponibles pour un seul message avec une description.

S.Non Classes et description
1

message-hide-name

C'est une classe supplémentaire pour masquer le nom d'un message pour un seul message (reçu ou envoyé).

2

message-hide-avatar

C'est une classe supplémentaire pour masquer l'avatar de message pour un seul message (reçu ou envoyé).

3

message-hide-label

C'est une classe supplémentaire pour masquer l'étiquette de message pour un seul message (reçu ou envoyé).

4

message-last

Vous pouvez utiliser cette classe pour indiquer le dernier message reçu ou envoyé dans la conversation en cours par un expéditeur pour un seul message (reçu ou envoyé).

5

message-first

Vous pouvez utiliser cette classe pour indiquer le premier message reçu ou le premier message envoyé dans la conversation en cours par un expéditeur pour un seul message (reçu ou envoyé).

Initialisation des messages avec JavaScript

Vous pouvez initialiser les messages avec JavaScript en utilisant la méthode suivante -

myApp.messages(messagesContainer, parameters)

La méthode prend deux options -

  • messagesContainer - Il s'agit d'un élément ou d'une chaîne HTML obligatoire qui inclut l'élément HTML du conteneur de messages.

  • parameters - Il spécifie un objet avec des paramètres de messages.

Paramètres des messages

Le tableau suivant montre les paramètres des messages avec une description.

S.Non Paramètre et description Type Défaut
1

autoLayout

Il ajoute des classes requises supplémentaires à chaque message en l'activant.

booléen vrai
2

newMessagesFirst

Vous pouvez afficher le message en haut au lieu d'afficher en bas en l'activant.

booléen faux
3

messages

Il affiche un tableau de messages dans lequel chaque message doit être représenté comme un objet avec des paramètres de message.

tableau -
4

messageTemplate

Il affiche le modèle de message unique.

chaîne -

Propriétés des messages

Le tableau suivant présente les propriétés des messages avec une description.

S.Non Propriété et description
1

myMessages.params

Vous pouvez initialiser les paramètres passés avec object.

2

myMessages.container

Définit l'élément DOM7 avec un conteneur HTML de barre de message.

Méthodes de messages

Le tableau suivant montre les méthodes de messages avec description.

S.Non Méthode et description
1

myMessages.addMessage(messageParameters, method, animate);

Le message peut être ajouté au début ou à la fin à l'aide du paramètre method.

Il a les paramètres suivants -

  • messageParameters - Il fournit des paramètres de message à ajouter.

  • method - C'est un type de chaîne qui ajoute un message au début ou à la fin du conteneur de messages.

  • animate- C'est un type booléen, qui ajoute un message sans aucune transition ni animation de défilement en le définissant sur false. Par défaut, ce sera vrai.

2

myMessages.appendMessage(messageParameters, animate);

Il ajoute un message à la fin du conteneur de messages.

3

myMessages.prependMessage(messageParameters, animate);

Il ajoute un message au début du conteneur de messages.

4

myMessages.addMessages(messages, method, animate);

Vous pouvez ajouter plusieurs messages à la fois.

Il a le paramètre suivant -

  • messages - Il fournit un tableau de messages à ajouter, qui doivent être représentés comme un objet avec des paramètres de message.

5

myMessages.removeMessage(message);

Il est utilisé pour supprimer le message.

Il a le paramètre suivant -

  • message - Il s'agit d'un élément ou d'une chaîne HTML obligatoire qui supprime l'élément de message.

6

myMessages.removeMessages(messages);

Vous pouvez supprimer les multiples messages.

Il a le paramètre suivant -

  • messages - C'est un tableau obligatoire avec des éléments HTML ou une chaîne qui supprime les messages.

sept

myMessages.scrollMessages();

Vous pouvez faire défiler les messages de haut en bas et vice versa en fonction du premier paramètre du nouveau message.

8

myMessages.layout();

La mise en page automatique peut être appliquée aux messages.

9

myMessages.clean();

Il est utilisé pour nettoyer les messages.

dix

myMessages.destroy();

Il est utilisé pour détruire les messages.

Paramètres de message unique

Le tableau suivant montre les paramètres d'un seul message avec une description.

S.Non Paramètre et description Type Défaut
1

text

Il définit le texte du message, qui peut être une chaîne HTML.

chaîne -
2

name

Il spécifie le nom de l'expéditeur.

chaîne -
3

avatar

Il spécifie la chaîne d'URL de l'avatar de l'expéditeur.

chaîne -
4

time

Il spécifie la chaîne d'heure du message comme «9:45 AM», «18: 35».

chaîne -
5

type

Il fournit le type de message s'il peut être envoyé ou reçu.

chaîne expédié
6

label

Il définit le libellé du message.

chaîne -
sept

day

Il donne la chaîne du jour du message comme «dimanche», «lundi», «hier», etc.

chaîne -

Initialisation des messages avec HTML

Vous pouvez initialiser les messages avec HTML sans JavaScript en utilisant la classe supplémentaire messages-init aux messages et utiliser les attributs data- pour passer les paramètres requis comme indiqué dans l'extrait de code ci-dessous -

...
   <div class = "page-content messages-content">
      <!-- Initialize the messages using additional "messages-init" class-->
      <div class = "messages messages-init" data-auto-layout = "true" data-new-messages-first = "false">
         ...

      </div>
   </div>
...

Exemple

L'exemple suivant illustre l'utilisation de messages dans le Framework7 -

<!DOCTYPE html>
<html>

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Messages</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
            <div class = "pages">
               <div data-page = "home" class = "page navbar-fixed toolbar-fixed">
                  
                  <div class = "navbar">
                     <div class = "navbar-inner">
                        <div class = "left"> </div>
                        <div class = "center">Messages</div>
                        <div class = "right"> </div>
                     </div>
                  </div>
                  
                  <div class = "toolbar messagebar">
                     <div class = "toolbar-inner">
                        <textarea placeholder = "Message"></textarea><a href = "#" class = "link">Send</a>
                     </div>
                  </div>
                  
                  <div class = "page-content messages-content">
                     <div class = "messages">
                        <div class = "messages-date">Friday, Apr 26 <span>10:30</span></div>
                        <div class = "message message-sent">
                           <div class = "message-text">Hello</div>
                        </div>
                        
                        <div class = "message message-sent">
                           <div class = "message-text">Happy Birthday</div>
                        </div>
                        
                        <div class = "message message-received">
                           <div class = "message-name">Smith</div>
                           <div class = "message-text">Thank you</div>
                           <div style = "background-image:url(/framework7/images/person.png)" class = "message-avatar"></div>
                        </div>
                        
                        <div class = "messages-date">Saturday, Apr 27 <span>9:30</span></div>
                        <div class = "message message-sent">
                           <div class = "message-text">Good Morning...</div>
                        </div>
                        
                        <div class = "message message-sent">
                           <div class = "message-text"><img src = "/framework7/images/gm.jpg"></div>
                           <div class = "message-label">Delivered</div>
                        </div>
                        
                        <div class = "message message-received">
                           <div class = "message-name">Smith</div>
                           <div class = "message-text">Very Good Morning...</div>
                           <div style = "background-image:url(/framework7/images/person.png)" class = "message-avatar"></div>
                        </div>
                     </div>
                  </div>
                  
               </div>
            </div>
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
         
      <script>
         var myApp = new Framework7();
         var $$ = Dom7;

         // It indicates conversation flag
         var conversationStarted = false;

         // Here initiliaze the messages
         var myMessages = myApp.messages('.messages', {
            autoLayout:true
         });

         // Initiliaze the messagebar
         var myMessagebar = myApp.messagebar('.messagebar');

         // Displays the text after clicking the button
         $$('.messagebar .link').on('click', function () {
         
            // specifies the message text
            var messageText = myMessagebar.value().trim();
            
            // If there is no message, then exit from there
            if (messageText.length === 0) return;

            // Specifies the empty messagebar
            myMessagebar.clear()

            // Defines the random message type
            var messageType = (['sent', 'received'])[Math.round(Math.random())];

            // Provides the avatar and name for the received message
            var avatar, name;
            
            if(messageType === 'received') {
               name = 'Smith';
            }
            
            // It adds the message
            myMessages.addMessage ({
            
               // It provides the message text
               text: messageText,
            
               // It displays the random message type
               type: messageType,
            
               // Specifies the avatar and name of the sender
               avatar: avatar,
               name: name,
            
               // Displays the day, date and time of the message
               day: !conversationStarted ? 'Today' : false,
               time: !conversationStarted ? (new Date()).getHours() + ':' + (new Date()).getMinutes() : false
            })

            // Here you can update the conversation flag
            conversationStarted = true;
         });

      </script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous messages.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/messages.html et la sortie s'affiche comme indiqué ci-dessous.

  • Lorsque vous tapez un message dans la boîte de message et cliquez sur le bouton Envoyer, il spécifie que votre message a été envoyé et s'affiche avec une couleur d'arrière-plan verte sur le côté droit.

  • Le message que vous recevez apparaît sur le côté gauche avec un arrière-plan gris avec le nom de l'expéditeur.

La description

Framework7 fournit une barre d'outils redimensionnable spéciale pour fonctionner avec le système de messagerie de l'application.

Le code suivant montre la disposition de la barre de message -

<div clas = "toolbar messagebar">
   <div clas = "toolbar-inner">
      <textarea placeholder = "Message"></textarea>
      <a href = "#" clas = "link">Send</a>
   </div>
</div>

Dans la barre de message, l'intérieur de la "page" est très important et se trouve à droite de "messages-content" -

<div class = "page toolbar-fixed">
   <!-- messagebar -->
   <div class = "toolbar messagebar">
      <div class = "toolbar-inner">
         <textarea placeholder = "Message"></textarea>
         <a href = "#" class = "link">Send</a>
      </div>
   </div>
   
   <!-- messages-content -->
   <div class = "page-content messages-content">
      <div class = "messages">
         ... messages
      </div>
   </div>
</div>

Vous pouvez utiliser la méthode suivante pour initialiser la barre de message avec JavaScript -

myApp.messagesbar(messagesbarContainer, parameters)

La méthode a deux options -

  • messagesbarContainer - Il s'agit d'un élément ou d'une chaîne HTML obligatoire qui inclut l'élément HTML du conteneur de la barre de messages.

  • parameters - Il spécifie un objet avec des paramètres de barre de messages.

Par exemple -

var myMessagebar = app.messagebar('.messagebar', {
   maxHeight: 200
});

Paramètre Messagebar

maxHeight- Il est utilisé pour définir la hauteur maximale de la zone de texte et sera redimensionné en fonction de la quantité de son texte. Le type de paramètre est nombre et la valeur par défaut est null .

Propriétés de la barre de messages

Le tableau suivant montre les propriétés de la barre de messages -

S.Non Propriétés et description
1

myMessagebar.params

Vous pouvez spécifier un objet avec des paramètres d'initialisation passés.

2

myMessagebar.container

Vous pouvez spécifier l'élément dom7 avec l'élément HTML du conteneur messagebar.

3

myMessagebar.textarea

Vous pouvez spécifier l'élément dom7 avec l'élément HTML messagebar textarea.

Méthodes de la barre de messages

Le tableau suivant montre les méthodes de la barre de messages -

S.Non Méthodes et description
1

myMessagebar.value(newValue);

Il définit la valeur / texte de la zone de texte de la barre de message et renvoie la valeur de la zone de texte de la barre de message, si newValue n'est pas spécifié.

2

myMessagebar.clear();

Il efface la zone de texte et met à jour / réinitialise la taille.

3

myMessagebar.destroy();

Il détruit l'instance de la barre de messages.

Initialiser Messagebar avec HTML

Vous pouvez initialiser la barre de messages à l'aide de HTML sans méthodes et propriétés JavaScript en ajoutant la classe messagebar-init à la .messagebar et vous pouvez transmettre les paramètres requis à l'aide des attributs de données .

Le code suivant spécifie l'initialisation de la barre de messages avec HTML -

<div class = "toolbar messagebar messagebar-init" data-max-height = "200">
   <div class = "toolbar-inner">
      <textarea placeholder = "Message"></textarea>
      <a href = "#" class = "link">Send</a>
   </div>
</div>

Accès à l'instance de Messagebar

Il est possible d'accéder à l'instance de la barre de messages, si vous l'initialisez en utilisant HTML; il est réalisé en utilisant la propriété f7 Message bar de son élément container.

var myMessagebar = $$('.messagebar')[0].f7Messagebar;
// Now you can use it
myMessagebar.value('Hello world');

Vous pouvez voir l'exemple de Messagebar, qui est expliqué dans ce lien

La description

Les notifications sont utilisées pour afficher les messages requis, qui apparaissent comme des notifications iOS Push (ou locales).

Le tableau suivant illustre l'utilisation des notifications en détail -

S.Non Utilisation et description des notifications
1 Notifications API JavaScript

Les notifications peuvent également être ajoutées ou fermées avec JavaScript en utilisant les méthodes d'application associées.

2 Disposition des notifications

Les notifications Framework7 seront ajoutées à l'aide de JavaScript.

3 Exemple iOS

Framework7 vous permet d'utiliser différents types de notifications dans votre mise en page iOS.

4 Exemple de matériau

Les notifications Framework7 peuvent également être utilisées dans la mise en page des matériaux.

La description

Le chargement différé retarde le processus de chargement de votre image sur une page donnée. Le chargement différé améliore les performances de défilement, accélère le chargement de la page et économise du trafic.

Les éléments de chargement différé et les images doivent être à l'intérieur de <div class = "page-content"> scrollable pour fonctionner correctement.

Le tableau suivant illustre l'utilisation de la charge différée -

S.Non Utilisation et description de la charge différée
1 Usage

La charge paresseuse peut être appliquée aux images, aux images d'arrière-plan et avec un effet de fondu.

2 Initier manuellement le Lazy Load

Après l'initialisation d'une page, si vous ajoutez manuellement des images de chargement différé, le chargement différé ne fonctionnera pas et vous devez utiliser des méthodes pour l'initialiser.

Il est possible de chargement de l' image de déclenchement manuellement à l'aide paresseux événement sur l' image / élément paresseux comme représenté ci - dessous -

$$('img.lazy').trigger('lazy');

$$('div.lazy').trigger('lazy');

Exemple

L'exemple suivant montre l'utilisation du chargement différé dans Framework7 -

<!DOCTYPE html>
<html class = "with-statusbar-overlay">

   <head>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Lazy Load</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
            <div class = "pages">
               <div data-page = "home" class = "page navbar-fixed">
                  
                  <div class = "navbar">
                     <div class = "navbar-inner">
                        <div class = "left"> </div>
                        <div class = "center">Lazy Load</div>
                        <div class = "right"> </div>
                     </div>
                  </div>
                  
                  <div class = "page-content">
                     <div class = "content-block">
                        <div class = "content-block-inner">
                           <p> <img data-src = "/framework7/images/pic4.jpg" 
                              width = "100%" class = "lazy lazy-fadeIn"></p>
                           
                           <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, 
                           sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. 
                           Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris 
                           nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in 
                           reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla 
                           pariatur.</p>
                           
                           <p> <img data-src = "/framework7/images/pic5.jpg" 
                              width = "100%" class = "lazy lazy-fadeIn"></p>
                              
                           <p>Sed ut perspiciatis unde omnis iste natus error sit 
                           voluptatem accusantium doloremque laudantium, totam rem aperiam, 
                           eaque ipsa quae ab illo inventore veritatis et quasi architecto 
                           beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia 
                           voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur 
                           magni dolores eos qui ratione voluptatem sequi nesciunt.</p>
                           
                           <p> <img data-src = "/framework7/images/background.jpg" 
                              width = "100%" class = "lazy lazy-fadeIn"></p>
                              
                           <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, 
                           sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. 
                           Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris 
                           nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in 
                           reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla 
                           pariatur.</p>
                           
                           <p> <img data-src = "/framework7/images/pic6.jpg"
                              width = "100%" class = "lazy lazy-fadeIn"></p>
                              
                           <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem 
                           accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab 
                           illo inventore veritatis et quasi architecto beatae vitae dicta sunt 
                           explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut 
                           odit aut fugit, sed quia consequuntur magni dolores eos qui ratione 
                           voluptatem sequi nesciunt.</p>
                           
                           <p> <img data-src = "/framework7/images/pic7.jpg" 
                              width = "100%" class = "lazy lazy-fadeIn"></p>
                           <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, 
                           sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. 
                           Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris 
                           nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in 
                           reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla 
                           pariatur.</p>
                           
                           <p> <img data-src = "/framework7/images/pic8.jpg" 
                              width = "100%" class = "lazy lazy-fadeIn"></p>
                              
                           <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. 
                           Praesent laoreet nisl eget neque blandit lobortis. Sed sagittis risus 
                           id vestibulum finibus. Cras vestibulum sem et massa hendrerit maximus. 
                           Vestibulum suscipit tristique iaculis. Nam vitae risus non eros auctor 
                           tincidunt quis vel nulla. Sed volutpat, libero ac blandit vehicula, est 
                           sem gravida lectus, sed imperdiet sapien risus ut neque.</p>
                           
                           <p><b>Using as background image:</b></p>
                           
                           <div data-background = "/framework7/images/pic7.jpg" 
                              style = "background: #aaa; height:60vw; background-size-cover" 
                              class = "lazy lazy-fadeIn">
                           </div>
                           
                           <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem 
                           accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab 
                           illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. 
                           Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, 
                           sed quia consequuntur magni dolores eos qui ratione voluptatem sequi 
                           nesciunt.</p>
                        </div>
                     </div>
                  </div>
                  
               </div>
            </div>
         </div>
      </div>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
      
      <script>var myApp = new Framework7();</script>
   </body>

</html>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous framework7_lazy_load.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/framework7_lazy_load.html et la sortie s'affiche comme indiqué ci-dessous.

  • L'exemple spécifie le chargement différé des images où les images seront chargées sur la page lorsque vous les faites défiler vers le bas.

La description

Framework7 fournit différents thèmes de couleurs pour vos applications.

Un thème de couleur fournit différents types de couleurs de thème utilisées pour fonctionner avec les applications en douceur, comme spécifié dans le tableau ci-dessous -

S.Non Type de thème et description
1 Couleurs du thème iOS

Vous pouvez utiliser 10 thèmes de couleurs iOS par défaut différents pour l'application.

2 Couleurs du thème du matériau

Framework7 fournit 22 thèmes de couleurs de matériaux par défaut différents pour l'application.

Application de thèmes de couleurs

Framework7 vous permet d'appliquer des thèmes de couleur sur différents éléments tels que la page, le bloc de liste, la barre de navigation, la ligne de boutons, etc. en utilisant la classe theme- [color] à l'élément parent.

Exemple

...
</body>

<div class = "page theme-gray">
   ...
</div>

<div class = "list-block theme-blue">
   ...
</div>

<div class = "navbar theme-green">
   ...
</div>

<div class = "buttons-row theme-red">
   ...
</div>

Thèmes de mise en page

Vous pouvez utiliser le thème de mise en page par défaut pour votre application en utilisant deux thèmes blanc et foncé . Les thèmes peuvent être appliqués en utilisant la classe layout- [theme] à l'élément parent.

Exemple

...
</body>

<div class = "navbar layout-white">
   ...
</div>

<div class = "buttons-row layout-dark">
   ...
</div>

Classes d'assistance

Framework7 fournit des classes d'assistance supplémentaires, qui peuvent être utilisées en dehors ou sans thèmes comme indiqué ci-dessous -

  • color-[color] - Il peut être utilisé pour changer la couleur du texte du bloc ou la couleur du bouton, lien, icône, etc.

  • bg-[color] - Il définit la couleur d'arrière-plan prédéfinie sur le bloc ou l'élément.

  • border-[color] - Il définit la couleur de bordure prédéfinie sur le bloc ou l'élément.

La description

Hairline est une classe qui ajoute une bordure 1px autour des images en utilisant la classe border. Avec la sortie de 1.x, hairlines a révisé le travail avec : after et : before pseudo éléments au lieu d'utiliser des bordures CSS.

Hairlines contient les règles suivantes -

  • :after- Ce pseudo élément est utilisé pour les lignes de cheveux en bas et à droite .

  • :before- Ce pseudo élément est utilisé pour les lignes de cheveux du haut et de gauche .

L'extrait de code suivant montre l'utilisation de : after element.

.navbar:after {
   background-color: red;
}

L'extrait de code suivant supprime la barre d'outils en bas de la ligne de cheveux -

.navbar:after {
   display:none;
}

.toolbar:before {
   display:none;
}

classe "sans frontière"

La racine des cheveux sera supprimée en utilisant une classe sans bordure et elle est prise en charge sur la barre de navigation, la barre d'outils, la carte et ses éléments.

Le code suivant est utilisé pour supprimer la racine des cheveux de la barre de navigation -

<div class = "navbar no-border">
   ...
</div>

La description

Template7 est un moteur JavaScript léger et adapté aux mobiles, qui représente Ajax et les pages dynamiques en tant que modèles Template7 avec un contexte spécifié et ne nécessite aucun script supplémentaire. Template7 est associé à Framework7 en tant que moteur de modèle léger par défaut, qui fonctionne plus rapidement pour les applications.

Performance

Le processus de compilation de la chaîne en fonction JS est le segment le plus lent de template7. Par conséquent, vous n'avez pas besoin de compiler le modèle plusieurs fois, une seule fois suffit.

//Here initialize the app
var myApp = new Framework7();

// After initializing compile templates on app
var searchTemplate = $('script#search-template').html();
var compiledSearchTemplate = Template7.compile(searchTemplate);

var listTemplate = $('script#list-template').html();
var compiledListTemplate = Template7.compile(listTemplate);

// Execute the compiled templates with required context using onPageInit() method
myApp.onPageInit('search', function (page) {

   // Execute the compiled templates with required content
   var html = compiledSearchTemplate({/*...some data...*/});

   // Do stuff with html
});

Template7 est un moteur de template léger utilisé comme bibliothèque autonome sans Framework7. Les fichiers Template7 peuvent être installés de deux manières:

  • Vous pouvez télécharger à partir du référentiel github Template7 .

  • Ou

  • Vous pouvez l'installer en utilisant la commande suivante via Bower -

bower install template7

La description

Dans Template7, vous pouvez compiler vos modèles automatiquement en spécifiant des attributs spéciaux dans une balise <script>.

Le code suivant montre la disposition de compilation automatique -

<script type = "text/template7" id = "myTemplate">
   <p>Hello, my name is {{name}} and i am {{age}} years old</p>
</script>

Vous pouvez utiliser les attributs suivants pour initialiser la compilation automatique -

  • type = "text/template7" - Il est utilisé pour indiquer à Template7 de se compiler automatiquement et c'est un type de script requis.

  • id = "myTemplate" - Le modèle est accessible via l'identifiant et il s'agit d'un identifiant de modèle obligatoire.

Pour la compilation automatique, vous devez activer l'initialisation de l'application en passant le paramètre suivant -

var myApp = new Framework7 ({
   //It is used to compile templates on app init in Framework7
   precompileTemplates: true,
});

Template7.templates / myApp.templates

Les modèles compilés automatiquement sont accessibles en tant que propriétés de Template7.templates après l'initialisation de l'application. Il est également connu sous le nom de myApp.templatesmyApp est une instance initialisée de l'application.

Vous pouvez utiliser les modèles suivants dans notre fichier index.html -

<script type = "text/template7" id = "personTemplate">
   <p>Hello, my name is {{name}} and i am {{age}} years old</p>
   <p>I work as {{position}} at {{company}}</p>
</script>
 
<script type = "text/template7" id = "carTemplate">
   <p>I have a great car, it is {{vendor}} {{model}}, made in {{year}} year.</p>
   <p>It has {{power}} hp engine with {{speed}} km/h maximum speed.</p>
</script>

Vous pouvez également accéder aux modèles en JavaScript après l' initialisation de l'application -

var myApp = new Framework7 ({
   //Tell Framework7 to compile templates on app init
    precompileTemplates: true
});
 
// Render person template to HTML, its template is already compiled and accessible as 
//Template7.templates.personTemplate
var personHTML = Template7.templates.personTemplate ({
   name: 'King Amit',
   age: 27,
   position: 'Developer',
   company: 'AngularJs'
});
 
// Compile car template to HTML, its template is already compiled and accessible as 
//Template7.templates.carTemplate
var carHTML = Template7.templates.carTemplate({
   vendor: 'Honda',
   model: 'city',
   power: 1200hp,
   speed: 300
});

La description

Modèle7 est un moteur de template JavaScript mobile d' abord avec handlebars.js comme la syntaxe. Il s'agit d'un moteur de modèle par défaut ultra léger et ultra-rapide dans Framework7.

Tout d'abord, nous devons transmettre le paramètre suivant lors de l'initialisation de l'application qui rend toutes les pages Ajax et dynamiques en tant que modèle Template7 -

var myApp = new Framework7 ({
   template7Pages: true // enable Template7 rendering for Ajax and Dynamic pages
});
S.Non Utilisation et description du modèle7 pages
1 Modèles / Données de pages

Vous pouvez transmettre les données / contexte requis pour des pages spécifiques en spécifiant toutes les données de pages dans le paramètre template7Data , envoyé lors de l'initialisation d'une application.

2 Passer le contexte personnalisé

Framework7 vous permet de transmettre un contexte personnalisé à n'importe quelle page dynamique ou à tout Ajax chargé.

3 Charger les modèles directement

Vous pouvez rendre et charger des modèles à la volée sous forme de pages dynamiques.

4 Requête d'URL

Si vous utilisez Template7 pour le rendu des pages Ajax, son contexte sera toujours étendu avec la propriété spéciale url_query .

Exemple

L'exemple suivant fournit les liens, qui affichent les informations de l'utilisateur telles que les détails de l'utilisateur, les préférences de l'utilisateur, etc. lorsque vous cliquez sur ces liens.

index.html

<!DOCTYPE html>
<html>

   <head>
      <meta charset = "utf-8">
      <meta name = "viewport" content = "width = device-width, initial-scale = 1, 
         maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" />
      <meta name = "apple-mobile-web-app-capable" content = "yes" />
      <meta name = "apple-mobile-web-app-status-bar-style" content = "black" />
      <title>Framework7</title>
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" />
      <link rel = "stylesheet" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" />
   </head>

   <body>
      <div class = "views">
         <div class = "view view-main">
            
            <div class = "navbar">
               <div class = "navbar-inner">
                  <div class = "center sliding">Template7 Pages</div>
               </div>
            </div>
            
            <div class = "pages navbar-through toolbar-through">
               <div data-page = "index" class = "page">
                  <div class = "page-content">
                     <div class = "list-block">
                        <ul>
                           <li>
                              //plain data objects allow to pass custom context to loaded page using 'data-context-name' attribute
                              <a href = "#" data-template = "about" data-context-name = "about" class = "item-link item-content">
                                 <div class = "item-inner">
                                    //provides link as 'About'
                                    <div class = "item-title">About</div>
                                 </div>
                              </a>
                           </li>
                           
                           <li>
                              //a context name for this link we pass context path from template7Data root
                              <a href = "/framework7/src/likes.html" class = "item-link item-content">
                                 <div class = "item-inner">
                                    //provides link as 'Likes'
                                    <div class = "item-title">Likes</div>
                                 </div>
                              </a>
                           </li>
                        </ul>
                     </div>
                  </div>
               </div>
            </div>
            
         </div>
      </div>
      
      <script type = "text/template7" id = "about">
         <div class = "navbar">
            <div class = "navbar-inner">
               <div class = "left sliding">
                  <a href = "#" class = "back link"> <i class = "icon icon-back"></i><span>Back</span></a>
               </div>
            
               <div class = "center sliding">About Me</div>
               <div class = "right">
                  <a href = "#" class = "link icon-only open-panel"> <i class = "icon icon-bars"></i></a>
               </div>
            </div>
         </div>
         
         <div class = "pages">
            <div data-page = "about" class = "page">
               <div class = "page-content">
                  <div class = "content-block">
                     <div class = "content-block-inner">
                        //displays the details of the user by using the 'my-app.js' file
                        <p>Hello, i am <b>{{firstname}} {{lastname}}</b>, 
                           <b>{{age}}</b> years old and working as 
                           <b>{{position}}</b> at <b>{{company}}</b>.</p>
                     </div>
                  </div>
               </div>
            </div>
         </div>
      </script>
      
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script>
         
      <script type = "text/javascript" 
         src = "/framework7/src/js/my-app.js">
      </script>
   </body>

</html>

mon-app.js

// Initialize your app
var myApp = new Framework7 ({
   animateNavBackIcon: true,
   
   // Enable templates auto precompilation
   precompileTemplates: true,
   
   // Enabled rendering pages using Template7
   template7Pages: true,
   
   // Specify Template7 data for pages
   template7Data: {
      //provides the url for different page with data-page = "likes"
      'url:likes.html': {
         likes: [
            {
               title: 'Nelson Mandela',
               description: 'Champion of Freedom'
            },
            
            {
               title: 'Srinivasa Ramanujan',
               description: 'The Man Who Knew Infinity'
            },
            
            {
               title: 'James Cameron',
               description: 'Famous Filmmaker'
            }
         ]
      },
      about: {
         firstname: 'William ',
         lastname: 'Root',
         age: 27,
         position: 'Developer',
         company: 'TechShell',
      }
   }
});

// Add main View
var mainView = myApp.addView('.view-main', {
   // Enable dynamic Navbar
   dynamicNavbar: true
});

likes.html

<div class = "navbar">
   <div class = "navbar-inner">
      <div class = "left sliding">
         <a href = "#" class = "back link"> <i class = "icon icon-back"></i><span>Back</span></a>
      </div>
      
      <div class = "center sliding">Likes</div>
      <div class = "right">
         <a href = "#" class = "link icon-only open-panel"> <i class = "icon icon-bars"></i></a>
      </div>
   </div>
</div>

<div class = "pages">
   <div data-page = "likes" class = "page">
      <div class = "page-content">
         <div class = "content-block-title">My Likes</div>
         <div class = "list-block media-list">
         
            //iterate through likes
            <ul>
               {{#each likes}}
                  <li class = "item-content">
                     <div class = "item-inner">
                        <div class = "item-title-row">
                           //displays the title and description by using the 'my-app.js' file
                           <div class = "item-title">{{title}}</div>
                        </div>
                        <div class = "item-subtitle">{{description}}</div>
                     </div>
                  </li>
               {{/each}}
            </ul>
         </div>
      </div>
   </div>
</div>

Production

Exécutons les étapes suivantes pour voir comment fonctionne le code donné ci-dessus -

  • Enregistrez le code HTML ci-dessus sous index.html fichier dans le dossier racine de votre serveur.

  • Ouvrez ce fichier HTML en tant que http: //localhost/index.html et la sortie s'affiche comme indiqué ci-dessous.

  • L'exemple fournit les liens, qui affichent les informations de l'utilisateur telles que les détails de l'utilisateur, que l'utilisateur aime lorsque vous cliquez sur ces liens.

La description

Lorsque vous appuyez sur les liens et les boutons, ils sont mis en surbrillance. Cela se fait par état actif dans Framework7.

  • Il se comporte comme une application native, pas comme une application Web.
  • Il dispose d'une bibliothèque de clics rapides intégrée et doit être activée.
  • La classe active-state est la même que le CSS : active selector.
  • L'état actif est activé en ajoutant la classe watch-active-state à l' élément <html> .

Le code suivant est utilisé pour l'état actif dans le style CSS -

/* Usual state */
.my-button {
   color: red;
}

/* Active/tapped state */
.my-button.active-state {
   color: blue;
}

Le code suivant montre la compatibilité de secours, lorsque l'état actif ou les clics rapides sont désactivés -

/* Usual state */
.my-button {
   color: red;
}

/* Active/tapped state */
.my-button.active-state {
   color: blue;
}

/* Fallback, when active state is disabled */
html:not(.watch-active-state) .my-button:active {
   color: blue;
}

La description

L'événement Tap Hold est utilisé pour déclencher (activer) après un événement tactile soutenu et terminé, donc seulement, il est appelé événement Tap Hold . La tabulation est une fonction intégréeFast Clicks bibliothèque.

Les paramètres suivants sont utilisés pour désactiver ou activer et configurés par défaut -

S.Non Paramètre et description Type Défaut
1

tapHold

Pour activer les événements de maintien de pression lorsqu'il est défini sur true.

booléen faux
2

tapHoldDelay

Il spécifie la durée de maintien du tap avant de déclencher l'événement taphold sur l'élément cible.

nombre 750
3

tapHoldPreventClicks

L'événement de maintien de pression ne sera pas déclenché après avoir cliqué sur l'événement.

booléen vrai

Le code suivant est utilisé pour activer les événements de maintien de pression -

var myApp = new Framework7 ({
   tapHold: true //enable tap hold events
});
 
var $$ = Dom7;
 
$$('.some-link').on('taphold', function () {
   myApp.alert('Tap hold fired!');
});

La description

Touch Ripple est un effet pris en charge uniquement dans le thème matériel Framework7. Par défaut, il est activé dans le thème des matériaux et vous pouvez le désactiver à l'aide du paramètre materialRipple: false .

Éléments d'ondulation

Vous pouvez activer les éléments d'ondulation pour qu'ils correspondent à certains sélecteurs CSS tels que -

  • ripple
  • a.link
  • a.item-link
  • .button
  • .tab-link
  • .label-radio
  • .label-case à cocher etc.

Ceux-ci sont spécifiés dans le paramètre materialRippleElements . Vous devez activer l' ondulation tactile , ajouter le sélecteur de l'élément au paramètre materialRippleElements pour utiliser l'effet d'entraînement, ou simplement utiliser la classe d' ondulation .

Couleur de l'onde ondulée

La couleur de l'ondulation peut être modifiée sur l'élément en ajoutant la classe ripple- [color] à l'élément.

Par exemple -

<a href = "#" class = "button ripple-orange">Ripple Button</a>

ou vous pouvez définir la couleur de l'onde ondulée en utilisant le CSS comme indiqué ci-dessous -

.button .ripple-wave {
   background-color: #FFFF00;
}

Désactiver les éléments d'ondulation

Vous pouvez désactiver l'ondulation pour certains éléments spécifiés en ajoutant la classe no-ripple à ces éléments. Par exemple -

<a href = "#" class = "button no-ripple">Ripple Button</a>