Heim > Web-Frontend > HTML-Tutorial > Drei Möglichkeiten, Ereignisse an HTML-Tag-Pseudoelemente zu binden

Drei Möglichkeiten, Ereignisse an HTML-Tag-Pseudoelemente zu binden

不言
Freigeben: 2019-03-30 10:47:28
nach vorne
4695 Leute haben es durchsucht

Dieser Artikel stellt Ihnen drei Möglichkeiten vor, Ereignisse an HTML-Tag-Pseudoelemente zu binden. Ich hoffe, dass er Ihnen als Referenz dienen wird.

In einem aktuellen Projekt bin ich auf die Funktion gestoßen, auf ein Symbol zu klicken, um bestimmte Vorgänge auszuführen. Es sollte sehr einfach zu implementieren sein, aber das Symbol wird durch ::after Pseudoelement implementiert Es scheint, dass die Pseudoelementoperation nicht direkt ausgeführt werden kann, aber alle Seiten im Projekt zeigen Symbole über Pseudoelemente an und es ist nicht möglich, die Symbole auf allen Seiten in DOM-Elemente umzuwandeln.
Nachdem ich im Internet nachgesehen habe, führen die meisten von ihnen die Methode ein, die Mauszeigerkoordinaten über das Ereignisobjekt abzurufen, um festzustellen, ob der angeklickte Bereich der Bereich ist, in dem sich das Pseudoelement befindet. Dies ist jedoch sehr mühsam.

Drei Möglichkeiten, Ereignisse an HTML-Tag-Pseudoelemente zu binden

Das Folgende ist eine Zusammenfassung mehrerer einfacher Möglichkeiten zur Handhabung der Ereignisverarbeitung beim Klicken auf Pseudoelemente, mit angehängtem Beispielcode.

HTML-Struktur

Zuallererst ist die HTML-Struktur so

<section>
    <span>按钮文字</span>
</section>
Nach dem Login kopieren

Implementierungsmethode

Die erste

über CSS3 Pointer-Events-Eigenschaften, die erreicht werden sollen.

CSS-Code

<style>
    *{margin: 0; padding:0;}
    section{
        border: 1px solid #abc;
        border-radius: 5px;
        background-color: #def;
        font-family: Microsoft YaHei;
        height: 40px;
        box-sizing: border-box;
        cursor: pointer;
        font-size: 16px;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);

        pointer-events: none;    /* 关键点在这里,元素禁止响应鼠标事件 */
    }

    section::after{
        content: &#39;&#39;;
        border-left: 1px solid #abc;
        display: inline-block;
        width: 24px;
        height: 100%;
        background-size: contain;
        background-position: center;
        background-image: url();

        pointer-events: auto;    /* 关键点在这里,伪元素覆盖父元素的 pointer-events: none ,响应鼠标事件 */
    }

    section span{
        display: inline-block;
        height: 100%;
        vertical-align: top;
        line-height: 40px;
        padding-left: 10px;
    }
</style>
Nach dem Login kopieren

JavaScript-Code

<script>
    document.querySelector(&#39;section&#39;).addEventListener(&#39;click&#39;, ()=>{
        console.log(&#39;只有点击伪元素才能触发click&#39;);
    });
</script>
Nach dem Login kopieren

Der zweite Typ

wird durch Verhindern von Event-Bubbling implementiert

CSS-Basiscode Das Gleiche wie Ändern Sie oben pointer-events: none und pointer-events: auto;

<script>
    document.querySelector(&#39;section&#39;).addEventListener(&#39;click&#39;, ()=>{
        // 因为其他子元素事件冒泡被阻止了,所以点击section的时候,只剩下伪元素覆盖区域进入到事件监听中
        console.log(&#39;只有伪元素才能触发click&#39;);
    });

    document.querySelector(&#39;span&#39;).addEventListener(&#39;click&#39;, ev=>{
        // 阻止文字元素的事件冒泡
        ev.stopPropagation();
    });
</script>
Nach dem Login kopieren

Die dritte Methode

Verwendet die Zeigerkoordinaten des Ereignisobjekts, um zu bestimmen, ob der Klick im Bereich des Pseudoelements liegt. Sie können es finden indem du nach Du Niang gehst.

Das Letzte ist, wenn es nicht funktioniert, verwenden Sie nicht ::. Ersetzen Sie es anschließend durch den tatsächlichen Dom-Knoten, ah O(∩_∩)O haha~

Dieser Artikel ist hier. Weitere spannende Inhalte finden Sie in der Spalte HTML-Video-Tutorial auf der chinesischen PHP-Website!


Das obige ist der detaillierte Inhalt vonDrei Möglichkeiten, Ereignisse an HTML-Tag-Pseudoelemente zu binden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:segmentfault.com
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