2015-03-17 32 views
19

Uso materiale angolare e desidero progettare un layout per la mia applicazione.Materiale angolare: come rendere scorrevole il contenuto

<!DOCTYPE html> 
<html lang="en"> 
<head> 
    <title>Angular Material - Starter App</title> 
    <meta charset="utf-8"> 
    <meta http-equiv="X-UA-Compatible" content="IE=edge"> 
    <meta name="description" content=""> 
    <meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no"/> 

    <link rel='stylesheet' href='http://fonts.googleapis.com/css?family=Roboto:400,700'> 
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/angular-material/0.8.3/angular-material.css"/> 
    <link rel="stylesheet" href="./style.css"/> 

</head> 

<body ng-app="starterApp" layout="column" layout-fill> 

    <div flex="30" style="border: 1px solid darkgrey;background-color: #1CA9F0;"></div> 
    <div flex style="border: 1px solid firebrick;" layout="column"> 
     <div flex="5" layout="row" layout-align="center"> 
      <md-toolbar flex="50"> 
       <h2 class="md-toolbar-tools"> 
        <span>Toolbar</span> 
       </h2> 
      </md-toolbar> 
     </div> 
     <div flex layout="row" layout-align="center"> 
      <md-content flex="50"> 
       Lorem ipsum dolor sit amet, ne quod novum mei. Sea omnium invenire mediocrem at, in lobortis conclusionemque nam. Ne deleniti appetere reprimique pro, inani labitur disputationi te sed. At vix sale omnesque, id pro labitur reformidans accommodare, cum labores honestatis eu. Nec quem lucilius in, eam praesent reformidans no. Sed laudem aliquam ne. 
       <p> 
        Facete delenit argumentum cum at. Pro rebum nostrum contentiones ad. Mel exerci tritani maiorum at, mea te audire phaedrum, mel et nibh aliquam. Malis causae equidem vel eu. Noster melius vis ea, duis alterum oporteat ea sea. Per cu vide munere fierent. 
       </p> 
       <p> 
        Ad sea dolor accusata consequuntur. Sit facete convenire reprehendunt et. Usu cu nonumy dissentiet, mei choro omnes fuisset ad. Te qui docendi accusam efficiantur, doming noster prodesset eam ei. In vel posse movet, ut convenire referrentur eum, ceteros singulis intellegam eu sit. 
       </p> 
       <p> 
        Sit saepe quaestio reprimique id, duo no congue nominati, cum id nobis facilisi. No est laoreet dissentias, idque consectetuer eam id. Clita possim assueverit cu his, solum virtute recteque et cum. Vel cu luptatum signiferumque, mel eu brute nostro senserit. Blandit euripidis consequat ex mei, atqui torquatos id cum, meliore luptatum ut usu. Cu zril perpetua gubergren pri. Accusamus rationibus instructior ei pro, eu nullam principes qui, reque justo omnes et quo. 
       </p> 
       <p> 
        Sint unum eam id. At sit fastidii theophrastus, mutat senserit repudiare et has. Atqui appareat repudiare ad nam, et ius alii incorrupte. Alii nullam libris his ei, meis aeterno at eum. Ne aeque tincidunt duo. In audire malorum mel, tamquam efficiantur has te. 
       </p> 
       <p> 
        Qui utamur tacimates quaestio ad, quod graece omnium ius ut. Pri ut vero debitis interpretaris, qui cu mentitum adipiscing disputationi. Voluptatum mediocritatem quo ut. Fabulas dolorem ei has, quem molestie persequeris et sit. 
       </p> 
       <p> 
        Est in vivendum comprehensam conclusionemque, alia cetero iriure no usu, te cibo deterruisset pro. Ludus epicurei quo id, ex cum iudicabit intellegebat. Ex modo deseruisse quo, mel noster menandri sententiae ea, duo et tritani malorum recteque. Nullam suscipit partiendo nec id, indoctum vulputate per ex. Et has enim habemus tibique. Cu latine electram cum, ridens propriae intellegat eu mea. 
       </p> 
       <p> 
        Duo at aliquid mnesarchum, nec ne impetus hendrerit. Ius id aeterno debitis atomorum, et sed feugait voluptua, brute tibique no vix. Eos modo esse ex, ei omittam imperdiet pro. Vel assum albucius incorrupte no. Vim viris prompta repudiare ne, vel ut viderer scripserit, dicant appetere argumentum mel ea. Eripuit feugait tincidunt pri ne, cu facilisi molestiae usu. 
       </p> 
       <p> 
        Qui utamur tacimates quaestio ad, quod graece omnium ius ut. Pri ut vero debitis interpretaris, qui cu mentitum adipiscing disputationi. Voluptatum mediocritatem quo ut. Fabulas dolorem ei has, quem molestie persequeris et sit. 
       </p> 
       <p> 
        Est in vivendum comprehensam conclusionemque, alia cetero iriure no usu, te cibo deterruisset pro. Ludus epicurei quo id, ex cum iudicabit intellegebat. Ex modo deseruisse quo, mel noster menandri sententiae ea, duo et tritani malorum recteque. Nullam suscipit partiendo nec id, indoctum vulputate per ex. Et has enim habemus tibique. Cu latine electram cum, ridens propriae intellegat eu mea. 
       </p> 

      </md-content> 
     </div> 
    </div> 
    <div flex="5" style="border: 1px solid turquoise;"></div> 


    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.14/angular.js"></script> 
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.14/angular-animate.min.js"></script> 
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.14/angular-aria.min.js"></script> 
    <script type="text/javascript" 
      src="https://cdnjs.cloudflare.com/ajax/libs/angular-material/0.8.3/angular-material.js"></script> 

    <script type="text/javascript"> 

     angular 
       .module('starterApp', ['ngMaterial']) 
       .run(function ($log) { 
        $log.debug("starterApp + ngMaterial running..."); 
       }); 

    </script> 

    </body> 
</html> 

La mia domanda è, come fare il md-contenuto scorrevole? Il div sul fondo dovrebbe essere un piè di pagina appiccicoso. Attenzione, su chrome sembra funzionante ma su Firefox no. Mi fido di Firefox, perché Chrome ha problemi con Flexbox.

Ho creato un plunker, ma non riesco a inserire il collegamento nel thread, appare sempre un messaggio di errore.

risposta

24

UPDATE

Questo problema non si presenta con angolare Materiale 1.1.1 - la domanda iniziale era al momento della versione 0.8.3

oRIGINALE

Usa anche i contenuti md sugli elementi esterni.

<body ng-app="starterApp" layout="column" layout-fill> 

    <div flex="30" style="border: 1px solid darkgrey;background-color: #1CA9F0;"></div> 
    <md-content flex style="border: 1px solid firebrick;" layout="column"> 
     <div flex="5" layout="row" layout-align="center"> 
      <md-toolbar flex="50"> 
       <h2 class="md-toolbar-tools"> 
        <span>Toolbar</span> 
       </h2> 
      </md-toolbar> 
     </div> 
     <md-content flex layout="row" layout-align="center"> 
      <md-content flex="50"> 
      ... 
      </md-content> 
     </md-content> 
    </md-content> 
    <div flex="5" style="border: 1px solid turquoise;"></div> 
    ... 
</body> 

[Plunkr] http://plnkr.co/edit/IfEtX638z4ymccC0Ua53?p=preview

Vedi: https://github.com/angular/material/issues/1906

+0

Questo si è rivelato un punto molto importante! – charneykaye

+4

secondo i documenti md-content non dovrebbe essere nidificato –

+0

Lo so, ma finora ha funzionato bene. Hai un'alternativa? – kuhnroyal

6

prova ad aggiungere style="overflow: scroll;" all'etichetta che desideri sia scorrevole.

Per esempio io ho nella mia:

<div layout="column" flex style="overflow: scroll;"> 
    <div id="content" ng-view flex></div> 
</div> 
+0

Grazie ma non funziona. –

+1

Usato qualcosa vicino a questo, quindi grazie! –

4

Non è sufficiente impostare overflow: scroll.

È necessario aggiungere position: absolute e impostare una dimensione del contenitore che deve essere scorrevole. Provare qualcosa di simile:

md-content{ 
    position: absolute; 
    height: 100px; 
} 

Per ulteriori informazioni dei contenitori scorrimento leggere this answer

Grazie.

-2

per rendere il md-contenuto scorrevole, aggiungere l'attributo md-scroll-y, in questo modo:

<md-content md-scroll-y> 
</md-content> 
+0

Questo non ha funzionato per me. – Noel

1

posso risolvere questo problema (materiale angolare 0.11.0)

index.html

<body ng-app="app" layout="column" > 
    <div flex layout="column" ng-include="'app/layout/shell.html'" ></div> 
<body> 

shell.html

<div layout="row" flex style="overflow: hidden;" ng-controller="Shell" layout-fill> 
    <div ng-include="'app/layout/left-side-nav.html'"></div> 
    <md-content flex layout="column" role="main" class="fondo" style="height: inherit"> 
     <div ng-include="'app/layout/app-toolbar.html'"></div> 
     <md-content flex style="background-color: transparent; flex-direction: column;" ng-hide="dataLoading.init"> 
      <div ui-view  style="background-color: transparent"></div> 
     </md-content> 
    </md-content> 
    <div ng-include="'app/layout/right-side-nav.html'"></div> 
</div> 
0

Ciò che ha funzionato per me era il seguente. Un facile modo è,

<div style="left:0; 
      top: 0; 
      overflow: auto; 
      min-height:auto; 
      max-height:100%; 
      height:300px;"> 

o aggiungerlo come CSS esterno.

Il trucco è di overflow. Se i dati sulla pagina escono, diventerà automaticamente scorrevole.

Inoltre, renderà i dati scorrevoli solo nel div come mostrato di seguito.

enter image description here

Problemi correlati