Heim >Web-Frontend >CSS-Tutorial >Verwenden Sie geschickt reines CSS, um den Mausklick- und Zieheffekt zu erzielen und die Interaktion lebendiger zu gestalten!

Verwenden Sie geschickt reines CSS, um den Mausklick- und Zieheffekt zu erzielen und die Interaktion lebendiger zu gestalten!

青灯夜游
青灯夜游nach vorne
2022-11-08 20:08:123386Durchsuche

In diesem Artikel erfahren Sie, wie Sie mit reinem CSS den Mausklick- und Drag-Effekt erzielen, um die Interaktion lebendiger zu gestalten. Ich hoffe, er ist für alle hilfreich!

Verwenden Sie geschickt reines CSS, um den Mausklick- und Zieheffekt zu erzielen und die Interaktion lebendiger zu gestalten!

Hintergrund

Ziehen Sie die Maus, um Elemente zu verschieben, was eine etwas komplizierte Interaktion darstellt.

In diesem Artikel brechen wir die Regeln und stellen Ihnen einen superstarken Mausklick- und Drag-Effekt vor, der mit reinem CSS erzielt werden kann. [Empfohlenes Lernen: CSS-Video-Tutorial]

In diesem vorherigen Artikel – Unglaubliche reine CSS-Mausfolge – haben wir viele interessante reine CSS-Mausfolgeeffekte vorgestellt, wie diesen:

Sie können es jedoch sehen dass bei dem obigen Effekt die Bewegung der Elemente nicht sehr gleichmäßig ist. Wenn Sie die obige Implementierung verstehen, wissen Sie, dass sie relativ große Einschränkungen aufweist.

In diesem Artikel verwenden wir immer noch nur CSS, um einen seidenweichen Mausklick- und Drag-Element-Bewegungseffekt zu erzielen.

Mausklicken und ziehen, um den Effekt zu verfolgen

OK, was bedeutet das? Schauen wir uns zunächst das einfachste schematische Diagramm an, um den Effekt zu erzielen, wenn man auf ein Element klickt und es ziehen kann, um es zu verschieben:

Okay, hier können Sie einen Moment innehalten, bevor Sie weiterlesen. Normalerweise muss dieser Effekt mit Hilfe von JavaScript erreicht werden. Aus Sicht der Leistung:

  • Ziehen Sie zuerst das Element. Sie können das Element beliebig verschieben Verwenden Sie JavaScript. Gibt es eine Möglichkeit, den Elementball von Punkt A nach Punkt B zu bewegen? Dieser Effekt unterscheidet sich völlig von dem, was reines CSS erreichen kann.

  • Die Antwort muss ja sein

    ! Der gesamte Prozess ist auch sehr clever. Hier müssen wir das leistungsstarke Attribut resize verwenden. Und durch die Konstruktion eines ausgeklügelten Layouts können wir verschiedene Probleme lösen, die auftreten können.

  • Verwenden Sie resize, um Elemente zu erstellen, die gezogen und in der Größe geändert werden können
<p></p>Zuerst verwenden wir den resize code>-Attribut zum Implementieren eines A-Elements mit veränderbarer Größe. <p><strong>Was ist <code>Größenänderung? Laut MDN – resize: Mit dieser CSS-Eigenschaft können Sie die Größenänderung steuern eines Elements. resize 属性。以及,配合通过构建一种巧妙的布局,去解决可能会遇到的各种难题。

使用 resize,构建可拖拽改变大小的元素

首先,我们利用 resize 属性来实现一个可改变大小的元素。

什么是 resize 呢?根据 MDN -- resize:该 CSS 属性允许你控制一个元素的可调整大小性。

其 CSS 语法如下所示:

{
/* Keyword values */
  resize: none;
  resize: both;
  resize: horizontal;
  resize: vertical;
  resize: block;
  resize: inline;
}

简单解释一下:

  • resize: none:元素不能被用户缩放
  • resize: both:允许用户在水平和垂直方向上调整元素的大小
  • resize: horizontal:允许用户在水平方向上调整元素的大小
  • resize: vertical:允许用户在垂直方向上调整元素的大小
  • resize: block:根据书写模式(writing-mode)和方向值(direction),元素显示允许用户在块方向上(block)水平或垂直调整元素大小的机制。
  • resize: inline:根据书写模式(writing-mode)和方向值(direction),元素显示一种机制,允许用户在内联方向上(inline)水平方向或垂直方向调整元素的大小。

看一个最简单的 DEMO:

<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. A aut qui labore rerum placeat similique hic consequatur tempore doloribus aliquid alias, nobis voluptates. Perferendis, voluptate placeat esse soluta deleniti id!</p>
p {
    width: 200px;
    height: 200px;
    resize: horizontal;
    overflow: scroll;
}

这里,我们设置了一个长宽为 200px<p></p>

Die CSS-Syntax lautet wie folgt: <p></p>
<div></div>
Eine kurze Erklärung:

    resize: none: Das Element kann vom Benutzer nicht skaliert werden

    🎜resize: Both code>: Erlaubt Benutzern, die Größe von Elementen horizontal und vertikal zu ändern Direction🎜🎜<code>resize: block: Abhängig vom Schreibmodus (writing-mode) und dem Richtungswert (direction) ermöglicht die Elementanzeige dem Benutzer, die Größe horizontal oder vertikal in Blockrichtung (block) zu ändern. Ein Mechanismus zum Ändern der Größe von Elementen. 🎜🎜resize: inline: Abhängig vom Schreibmodus (writing-mode) und dem Richtungswert (direction) zeigt das Element einen Mechanismus an, der es dem Benutzer ermöglicht, horizontal oder vertikal in Inline-Richtung anzupassen ( inline) Die Größe des Elements. 🎜🎜🎜Schauen Sie sich die einfachste DEMO an: 🎜
    .g-resize {
        width: 100px;
        height: 100px;
        border: 1px solid deeppink;
    }
    .g-resize {
        width: 100px;
        height: 100px;
        border: 1px solid deeppink;
        resize: both;
        overflow: scroll;
    }
    🎜Hier legen wir einen <p></p> mit einer Länge und Breite von 200px fest, damit er horizontal nach gezogen werden kann Ändern Sie die Breite. Die Wirkung ist wie folgt: 🎜🎜🎜🎜🎜Eine kurze Zusammenfassung einiger Tipps: 🎜
    • resize 的生效,需要配合 overflow: scroll,当然,准确的说法是,overflow 不是 visible,或者可以直接作用于替换元素譬如图像、<video></video><iframe></iframe><textarea></textarea>
    • 我们可以通过 resizehorizontalverticalboth 来设置横向拖动、纵向拖动、横向纵向皆可拖动。
    • 可以配合容器的 max-widthmin-widthmax-heightmin-height 限制可拖拽改变的一个范围

    这里,如果你的对 resize 还有所疑惑,或者想了解更多 resize 的有趣用法,可以看看我的这篇文章:CSS 奇思妙想 | 使用 resize 实现强大的图片拖拽切换预览功能

    将 resize 应用到本文实例中

    OK,接下来,我们将 resize 实际运用到我们本文的例子中去,首先,我们先简单实现一个 DIV:

    <div></div>
    .g-resize {
        width: 100px;
        height: 100px;
        border: 1px solid deeppink;
    }

    如下,非常普通,没有什么特别的:

    但是,通过给这个元素加上 resize: both 以及 overflow: scroll,此时,这个元素的大小就通过元素右下角的 ICON 进行拖动改变。

    简单修改下我们的 CSS 代码:

    .g-resize {
        width: 100px;
        height: 100px;
        border: 1px solid deeppink;
        resize: both;
        overflow: scroll;
    }

    这样,我们就得到了一个灵活可以拖动的元素:

    是的,我们的整个效果,就需要借助这个特性进行实现。

    在此基础上,我们可以尝试将一个元素定位到上面这个可拖动放大缩小的元素的右下角,看着能不能实现上述的效果。

    简单加一点代码:

    <div></div>
    .g-resize {
        position: relative;
        width: 20px;
        height: 20px;
        resize: both;
        overflow: scroll;
    }
    .g-resize::before {
        content: "";
        position: absolute;
        bottom: 0;
        right: 0;
        width: 20px;
        height: 20px;
        border-radius: 50%;
        background: deeppink;
    }

    我们利用元素的伪元素实现了一个小球,放置在容器的右下角看看效果:

    如果我们再把整个设置了 resize: both 的边框隐藏呢?那么效果就会是这样:

    Wow,整个效果已经非常的接近了!只是,认真看的话,能够看到一些瑕疵,就是还是能够看到设置了 resize 的元素的这个 ICON:

    这个也好解决,在 Chrome 中,我们可以通过另外一个伪元素 ::-webkit-resizer ,设置这个 ICON 的隐藏。

    根据 MDN - ::-webkit-resizer,它属于整体的滚动条伪类样式家族中的一员。

    其中 ::-webkit-resizer 可以控制出现在某些元素底角的可拖动调整大小的滑块的样式。

    所以,这里我就利用这个伪类:

    .g-resize {
        position: relative;
        width: 20px;
        height: 20px;
        resize: both;
        overflow: scroll;
    }
    .g-resize::before {
        content: "";
        position: absolute;
        bottom: 0;
        right: 0;
        width: 20px;
        height: 20px;
        border-radius: 50%;
        background: deeppink;
    }
    .g-resize::-webkit-resizer {
        background-color: transparent;
    }

    这样,这里的核心在于利用了 .g-resize::-webkit-resizer 中的 background-color: transparent,将滑块的颜色设置为了透明色。我们就得到了与文章一开始,一模一样的效果:

    解决溢出被裁剪问题

    当然,这里有个很致命的问题,如果需要移动的内容,远比设置了 resize 的容器要大,或者其初始位置不在该容器内,超出了的部分因为设置了 overflow: scroll,将无法看到。

    因此上述方案存在比较大的缺陷。

    举个例子,假设我们需要被拖动的元素不再是一个有这样一个简单的结构:

    <div></div>
    .g-content {
        width: 100px;
        height: 100px;
        background: black;
        pointer-event: none;
        
        &::before {
            content: "";
            position: absolute;
            width: 20px;
            height: 20px;
            background: yellow;
            border-radius: 50%;    
    }

    而像是这样,是一个更为复杂的布局内容展示(当然下面展示的也比较简单,实际中可以想象成任意复杂结构内容):

    如果将这个结构,扔到上面的 g-resize 中:

        <div></div>

    那么就会因为设置了 overflow: scroll 的原因,将完全看不到,只剩下一小块:

    为了解决这个问题,我们得修改原本的 DOM 结构,另辟蹊径。

    方法有很多,譬如可以利用 Grid  布局的一些特性。当然,这里我们只需要巧妙的加多一层,就可以完全解决这个问题。

    我们来实现这样一个布局:

        <div></div>     <div></div>

    解释一下上述代码,其中:

    • g-container 设置为绝对定位加上 display: inline-block,这样其盒子大小就可以由内部正常流式布局盒子的大小撑开

    • g-resize 设置为 position: relative 并且设置 resize,负责提供一个可拖动大小元素,在这个元素的变化过程中,就能动态改变父容器的高宽

    • g-content 实际内容盒子,通过 position: absolute 定位到容器的右下角即可

    看看完整的 CSS 代码:

    .g-container {
        position: absolute;
        display: inline-block;
    }
    .g-resize { 
        content: "";
        position: relative;
        width: 20px;
        height: 20px;
        border-radius: 50%;
        resize: both;
        overflow: scroll;
        z-index: 1;
    }
    .g-content {
        position: absolute;
        bottom: -80px;
        right: -80px;
        width: 100px;
        height: 100px;
        background: black;
        pointer-event: none;
        
        &::before {
            content: "";
            position: absolute;
            width: 20px;
            height: 20px;
            background: yellow;
            border-radius: 50%;
            transition: .3s;
        }
    }
    .g-container:hover .g-content::before {
        transform: scale(1.1);
        box-shadow: -2px 2px 4px -4px #333, -4px 4px 8px -4px #333;
    }
    .g-resize::-webkit-resizer {
        background-color: transparent;
    }

    下图中,你看到的所有元素,都只是 g-content 呈现出来的元素,整个效果就是这样:

    是的,可能你会有所疑惑,下面我用简单不同颜色,标识不同不同的 DOM 结构,方便你去理解。

    • 红色边框表示整个 g-container 的大小

    • 用蓝色矩形表示设置了 g-resize 元素的大小

    • 关掉 ::-webkit-resizer 的透明设置,展示出 resize 框的可拖拽 ICON

    .g-container {
        border: 3px solid red;
    }
    .g-resize { 
        content: "";
        background: blue;
        resize: both;
        overflow: scroll;
    }
    .g-resize::-webkit-resizer {
        // background-color: transparent;
    }

    看看这个图,整个原理基本就比较清晰的浮现了出来:

    完整的原理代码,你可以戳这里:CodePen Demo -- Pure CSS Auto Drag Demo

    实际应用

    OK,用了比较大篇幅对原理进行了描述。下面我们举一个实际的应用场景。使用上述技巧制作的可拖动便签贴。灵感来自 -- scottkellum

    代码也不多,如果你了解了上面的内容,下面的代码将非常好理解:

        <div></div>     
     Lorem ipsum dolor sit amet consectetur?

    完整的 CSS 代码如下:

    body {
        position: relative;
        padding: 10px;
        background: url("背景图");
        background-size: cover;
    }
    .g-container {
        position: absolute;
        display: inline-block;
    }
    .g-resize {
        content: "";
        position: relative;
        width: 20px;
        height: 20px;
        resize: both;
        overflow: scroll;
        z-index: 1;
    }
    .g-content {
        position: absolute;
        bottom: -160px;
        right: -180px;
        color: rgba(#000, 0.8);
        background-image: linear-gradient(
            160deg,
            rgb(255, 222, 30) 50%,
            rgb(255, 250, 80)
        );
        width: 200px;
        height: 180px;
        pointer-event: none;
        text-align: center;
        font-family: "marker felt", "comic sans ms", sans-serif;
        font-size: 24px;
        line-height: 1.3;
        padding: 1em;
        box-sizing: border-box;
        &:before {
            content: "";
            position: absolute;
            width: 20px;
            height: 20px;
            top: 0;
            left: 0;
            border-radius: 50%;
            background-image: radial-gradient(
                at 60% 30%,
                #f99,
                red 20%,
                rgb(180, 8, 0)
            );
            background-position: 20% 10%;
            cursor: pointer;
            pointer-events: none;
            transform: scale(0.8);
            box-shadow: -5px 10px 3px -8.5px #000, -1px 7px 12px -5px #000;
            transition: all 0.3s ease;
            transform: scale(0.8);
        }
    }
    .g-container:hover .g-content::before {
        transform: scale(0.9);
        box-shadow: -5px 10px 6px -8.5px #000, -1px 7px 16px -4px #000;
    }
    .g-resize::-webkit-resizer {
        background-color: transparent;
    }

    我们通过上述的技巧,实现了一个仅仅使用 CSS 实现的自由拖拽的便签贴。我们可以自由的将其拖拽到任意地方。看看效果:

    Verwenden Sie geschickt reines CSS, um den Mausklick- und Zieheffekt zu erzielen und die Interaktion lebendiger zu gestalten!

    当然,我们可以再配合上另外一个有意思是 HTML 属性 -- contenteditable

    contenteditable 是一个 HTML TAG 的属性,表示元素是否可被用户编辑。如果可以,浏览器会修改元素的部件以允许编辑。

    简单修改一下 DOM 结构:

        <div></div>     
     Lorem ipsum dolor sit amet consectetur?

    此时,元素不仅可以被拖动,甚至可以被重写,感受一下:

    纯 CSS 实现的效果,非常的有意思,完整的代码,你可以戳这里:Pure CSS Auto Drag Demo

    最后

    基于 resize 这个 CSS 属性,其实还有很多有意思的用法。譬如我之前使用了 Resize 实现了一个图片切换预览的功能:CSS 奇思妙想 | 使用 resize 实现强大的图片拖拽切换预览功能 可以一并看看,相信能碰撞出更多火花。

    原文地址:https://www.cnblogs.com/coco1s/p/16774696.html

    作者:ChokCoco

    (学习视频分享:web前端

Das obige ist der detaillierte Inhalt vonVerwenden Sie geschickt reines CSS, um den Mausklick- und Zieheffekt zu erzielen und die Interaktion lebendiger zu gestalten!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:cnblogs.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen