Heim > Web-Frontend > CSS-Tutorial > Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle

Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle

不言
Freigeben: 2018-08-09 13:49:31
Original
2718 Leute haben es durchsucht

Dieser Artikel führt Sie in das Flex-Layout ein, um das Layout der NetEase Cloud-Player-Schnittstelle zu realisieren. Ich hoffe, dass es für Sie hilfreich ist.

Heute werden wir uns mit den Details des Projekts befassen und über die Hürden sprechen, die jeder Grafikschneider nicht umgehen kann. Es ist auch eine regelmäßige Aufgabe, der sich jser stellen muss – „NetEase Cloud Music Highly Reusable Responsive Carousel Graphics“ Realisierung von „.

Karussellbilder sind für die Arbeit eines jeden genauso wichtig wie die Vorbereitungen für Ihren ersten Ausflug zum Haus Ihrer Freundin. Sie sind wichtig und können nicht umgangen werden. Leider schreiben die meisten Leute Karussellbilder, als ob sie ihre Eltern zum ersten Mal treffen würden und wenig Erfahrung hätten.

Viele Leute möchten selbst eine Reihe von Karussells schreiben und diese dann in ihrer zukünftigen Arbeit weiter verbessern und schließlich ihre eigene Plug-In-Bibliothek erstellen. Leider finden die meisten Leute, die diese Idee haben, erst heraus, wann Sie ergreifen Maßnahmen, dies ist noch schwieriger, als das Versprechen zu erfüllen, „eine Wohnung zu kaufen, wenn man heiratet“. Am Ende blieb mir aufgrund des Projektdrucks und meines eigenen Kenntnisstands keine andere Wahl, als Plug-In-Porter zu werden.

Aber es gibt drei Probleme mit dem Plug-in-Porter. Erstens ist dies für das technische Wachstum einer Person nicht von Nutzen Erfülle die Projektanforderungen und bin nicht in der Lage, eine sekundäre Entwicklung durchzuführen. Wenn ich auf seltsame Dinge stoße, kann sich der Fehler nur mit seinem Schicksal abfinden und die langsame Reise fortsetzen, ein geeigneteres Plug-In zu finden. Schließlich sind einige Plugins schwer und aufgebläht, aber alles, was Sie brauchen, ist die grundlegendste Karussell-Funktionalität. Würden Sie Knödel machen, nur um einen Teller Essig zu haben? Das glaube ich nicht. Warum verwenden Sie dann Hunderte von K- oder sogar M-Plug-Ins im Projekt, nur um ein Karussell zu verwenden?

Viele Leute sagen vielleicht, dass es daran liegt, dass sie nicht wissen, wie man schreibt. Sie werden feststellen, dass die Welt von js so einfach und schön ist -Ins können Sie 8 A-Plug-Ins entwickeln.

Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle

Schau nach, jeder weiß, was ein Karussellbild ist, schau dir mal genauer an, was du im ersten Schritt machen musst, zumindest sagen Ich ziehe es. Etwas muss sich bewegen können, auch wenn es ein rotes Quadrat ist. Hier müssen wir über das Ziehen sprechen. Durch Ziehen werden nichts weiter als die Werte für links und oben geändert (nur Außerirdische ändern die Werte für rechts und unten. Wir Erdlinge verwenden im Allgemeinen links und oben. Fragen Sie mich nicht warum). Lassen Sie ihn zunächst in eine Richtung gehen.

nbsp;html>


    <meta>
    <meta>
    <meta>
    <title>Document</title>
    <style>
        #p1 {
            width: 100px;
            height: 100px;
            position: absolute;
            left: 50px;
            top: 50px;
            background: red;
        }
    </style>
    <script>
        document.addEventListener("DOMContentLoaded", function () {
            var op = document.getElementById(&#39;p1&#39;);

            var disX = 0;
            op.addEventListener("touchstart", function (e) {
                var startPoint = e.changedTouches[0].pageX;
                var startLeft = op.offsetLeft;
                disX = startPoint - startLeft;
            });

            op.addEventListener("touchmove", doMove,false);
            function doMove(e) {
                var currPoint = e.changedTouches[0].pageX;
                var newLeft  = currPoint - disX;
                op.style.left = newLeft +&#39;px&#39;;
            }
            function doUp(e) {
                var currPoint = e.changedTouches[0].pageX;
                var newLeft  = currPoint - disX;
                op.style.left = newLeft +&#39;px&#39;;
                op.removeEventListener("touchmove", doUp,false);
                op.removeEventListener("touchend", doUp,false);
            }
            op.addEventListener("touchend", doUp,false);
        }, false);
    </script>


    <p></p>

Nach dem Login kopieren

Schauen Sie genau hin, es ist nichts anderes als die Verwendung mobiler Ereignisse. Das Problem ist, dass viele Schüler sagen werden: „Lehrer, ich verstehe das nicht, was ist das?“

 var currPoint = e.changedTouches[0].pageX;
 var newLeft  = currPoint - disX;
 op.style.left = newLeft +'px';
Nach dem Login kopieren

Was ist das?

var currPoint = e.changedTouches[0].pageX;
var newLeft  = currPoint - disX;
op.style.left = newLeft +'px';
op.addEventListener("touchmove", doUp,false);
op.addEventListener("touchend", doUp,false);
Nach dem Login kopieren
Eigentlich handelt es sich um ein Bild, ein sehr einfaches Bild.

Man kann es auf einen Blick verstehen.

Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle

Tatsächlich wird die Position als Abstand der blauen Linie berechnet Wenn Sie es wirklich nicht verstehen können, ist es in Ordnung. Es ist nichts Falsches daran, es als Formel auswendig zu lernen. Mit diesen Grundkenntnissen wird es einfach sein, ein Regal einzurichten. Jetzt können Sie es einfach per Drag & Drop machen . Karussell ist einfacher als das Ziehen.

Das Problem ist, dass jedes Element des Karussells nicht an die richtige Position gelangt , der Wert von left ändert sich jedes Mal, wenn es sich um ein Karussellbild handelt, Bild oben.

Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle

Machen Sie sich keine Sorgen um die Breite des Mobiltelefonbildschirms. Es wird jedes Mal um ein Raster verschoben. Dann muss ich nur noch einen iNow-Wert festlegen und aufzeichnen, wie viele Raster ich verschieben muss. Solange der iNow-Wert korrekt ist, ist alles in Ordnung.

nbsp;html>



    <meta>
    <meta>
    <style>
        * {
            margin: 0;
            padding: 0;
        }

        li {
            list-style: none;
        }

        .swiper-container {
            width: 320px;
            height: 130px;
            position: relative;
            margin: 20px auto;
            overflow: hidden;
        }

        .swiper-container .swiper-wrapper {
            width: 2240px;
            height: 130px;
            position: absolute;
            left: 0px;
        }

        .swiper-container .swiper-wrapper img {
            width: 320px;
            height: 130px;
            float: left;
            display: block;
        }

        .swiper-container ul {
            width: 35px;
            height: 4px;
            position: absolute;
            bottom: 10px;
            left: 50%;
            margin-left: -15px;
        }

        .swiper-container ul li {
            width: 4px;
            height: 4px;
            border-radius: 2px;
            border: 0.25px solid #fff;
            margin-left: 2.5px;
            background: #666;
            float: left;
            cursor: pointer;
        }

        .swiper-container ul .active {
            background: #fff;
        }

        .swiper-container ul li:hover {
            background: #fff;
        }
    </style>



    <p>
        </p><p>
            <img  alt="Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle" >
            <img  alt="Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle" >
            <img  alt="Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle" >
            <img  alt="Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle" >
            <img  alt="Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle" >
            <img  alt="Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle" >
            <img  alt="Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle" >
        </p>
        
Nach dem Login kopieren
                
  •             
  •             
  •             
  •             
  •         
         <script> document.addEventListener("DOMContentLoaded", function () { var oSWiperContainer = document.querySelector(".swiper-container"); var oSWiperWrapper = document.querySelector(".swiper-container .swiper-wrapper"); var aImg = document.querySelectorAll(".swiper-container .swiper-wrapper img") var aLi = document.querySelectorAll(".swiper-container ul li"); oSWiperContainer.addEventListener("touchstart", function (e) { var disX = 0; var startPoint = e.changedTouches[0].pageX; var startLeft = oSWiperWrapper.getBoundingClientRect().left; disX = startPoint - startLeft; oSWiperContainer.addEventListener("touchmove", doMove, false); oSWiperContainer.addEventListener("touchend", doUp, false); function doMove(e) { var currPoint = e.changedTouches[0].pageX; var newLeft = currPoint - disX; oSWiperWrapper.style.left = newLeft + &#39;px&#39;; } function doUp(e) { oSWiperContainer.removeEventListener("touchmove", doUp, false); oSWiperContainer.removeEventListener("touchend", doUp, false); } }, false); }, false); </script> Zur Betonung: getBoundingClientRect(), warum habe ich hier nicht offsetLeft verwendet? Denn in tatsächlichen Projekten ist es unmöglich, die äußere Schicht des Karussells mit nichts zu bedecken, oder wenn ein Rand und eine Polsterung vorhanden sind, ist der Abstand des Karussells falsch. Die Verwendung von offsetLeft ist für das Projekt nicht praktikabel, und das ist es auch okay für Demonstrationen, das eigentliche Projekt wäre nutzlos, wenn es so geschrieben würde. Abschließend werde ich über ein unendliches Karussell sprechen, das tatsächlich Zahlen zählt!

Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle

) Das sogenannte Unendliches Karussell Das Prinzip der Übertragung besteht darin, dass, wenn iNow ganz rechts gleich 0 ist, es in die Position des roten Kästchens zurückgezogen wird. Wenn iNow ganz links gleich 4 ist, ist iNow gleich 6.

Viele Leute haben die Quelle Der Code ignoriert das grundlegende Lernen und wird direkt verwendet. Es unterscheidet sich nicht von der direkten Suche nach dem Plug-In, also betrachten Sie dies einfach als eine kleine Übung.

Vier Übungen:

1. Implementieren Sie die Multi-Screen-Anpassung

2. Implementieren Sie das drahtlose Karussell

3. Implementieren Sie, wenn der Gleitabstand 50 Pixel nicht überschreitet wird den nächsten nicht senden

4. Automatische Timer-Rotation implementieren!

Das Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle

Hier habe ich den Code zur Erinnerung auf die linke Seite der oben genannten vier Übungslösungen eingefügt, und jeder sollte versuchen, zu lernen, wie man ihn umsetzt.

Empfohlene verwandte Artikel:

Detaillierte Erläuterung des Flex-Layouts

So verwenden Sie das Flex-Layout zum Verteilen von Spalten

Einführung in CSS3 Flex Layout application_html/css_WEB-ITnose

Das obige ist der detaillierte Inhalt vonDas Flex-Layout implementiert das Layout der NetEase Cloud-Player-Schnittstelle. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage