Ich möchte eine reaktionsfähige Trapezform erstellen, die entweder CSS, SVG oder Canvas enthalten kann.
Ich konnte die Dreiecksform erzeugen, aber keine trapezförmige Form, die reagiert.
Ich habe gesehen, dass es viele Fragen zu SO gibt, die eine Trapezform umfassen, aber sehr wenig Gründe haben, warum sie besser sind als andere Methoden und auch eine große Mehrheit nicht anspricht.
Zum Beispiel erfordern diese Fragen keine Reaktionsfähigkeit und daher reagieren die Antworten nicht:
Es gibt viele verschiedene Möglichkeiten, die trapezförmige Form zu erzeugen und jede hat ihre eigenen Vorteile und Nachteile.
Im Folgenden finden Sie eine umfassende Liste der verschiedenen Möglichkeiten und alle sollten reagieren.
Von allen Antworten am besten unterstützt. Es ist Unterstützung zurück zu IE und über alle anderen Browser sowohl auf dem Desktop als auch mobil.
Ein ziemlich neuer Ansatz innerhalb von CSS ist die perspektivische Methode in CSS Transforms. Es wird jetzt in allen modernen Browsern ziemlich gut unterstützt, aber es kann ziemlich schwierig sein, die exakte Formgröße zu erhalten, die Sie wollen.
Clip-Pfade erstellen einen SVG-Clip und verwenden diesen, um die gewünschte Form zu erstellen. Es ist der simpelste Weg (zumindest meiner Meinung nach), alle Formen mit reinem CSS zu erstellen, wird aber selbst in modernen Browsern nicht sehr gut unterstützt.
Diese Antwort wurde mir von web-tiki
gegebenEs ist vergleichbar mit der perspektivischen Antwort, indem es Transformationen verwendet, aber auch Pseudoelemente verwendet, die stattdessen den Skew aufweisen.
SVG steht für Scalable Vector Graphic. Der Webbrowser betrachtet es als Bild, aber Sie können Text und normale HTML-Elemente innerhalb eines SVGs hinzufügen.
Es wird von allen Browsern unterstützt, die hier zu sehen sind: CanIUse
Canvas ähnelt SVG, verwendet jedoch ein Raster (pixelbasiert) anstelle eines Vektors, um die Form zu erstellen.
Die Browserunterstützung für Canvas ist ziemlich gut.
Ich werde die fehlende Methode der obigen Antwort hinzufügen:
Tags und Links html css svg css3 css-shapes