css - 如何在网格中的列间隙区域内绘制分隔线

标签 css grid-layout css-grid

在这里写了一个jsbin https://jsbin.com/famuyodeye/2/edit?html,output

  <style>
    .grid-container {
        display: grid;
        grid:100%/1fr 1fr;
        grid-gap: 10px;
        margin: 10px;
    }

    .grid-item {
        overflow: hidden;
        width: 100%; 
    }
    img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    }
</style>


<div class="grid-container" style="height:400px;">
    <div class="grid-item">
        <img src="./a.jpg">
    </div>
    <div class="grid-item">
        <img src="./b.jpg">
    </div>
</div>

假设我放置了一个简单的 2 列网格并在其中放置了 2 张图像

我想添加一个鼠标悬停交互,当鼠标悬停在空白区域时,会显示一个分隔按钮,稍后我可以添加一些拖动功能来调整网格宽度。

我也许可以通过大量的 JS 来实现这一点,但是有没有一种聪明的方法,我的意思是最好少用 js,只使用 css 来实现这一点?

enter image description here

最佳答案

是的,你可以只用 css 来做,也看看这个工作代码框:- code for drag bar to show on hover

编辑代码:Edited code

  <style>
    .grid-container {
      color: white;
        display: grid;
        grid:100%/1fr 1fr;
        /* grid-gap: 10px; */
        margin: 10px;
/*       position: relative; */
    }

    .grid-item {
        position: relative;
        color: white;
        overflow: hidden;
        width: calc(100% + 10px);
        /* margin-right: 10px; */
        /* padding-right: 10px; */
    }
    .drag-bar{
      /* width: 200px; */
      position: absolute;
      left: 0;
      top:50%;
      width: 20px;
      height: 50px;
      z-index: 9999999;
      visibility: hidden;
    }
    .hover-bar{
      color: blue;
      position: absolute;
      right:0;
      top:0%;
      z-index: 9999999;
      height: 400px;
      width:8px;
      border: 1px solid blue;
    }
    .hover-bar:hover > .drag-bar{
      opacity: 1;
      visibility: visible;
      border: 2px solid blue;
    }
    img{
      width: calc(100% - 20px);
      height: 100%;
      object-fit: cover;
    }
</style>  

<div class="grid-container" style="height:400px;">
    <div class="grid-item">
        <img src="">
        <div class="hover-bar"><div class="drag-bar" ><img style="width:100%;" src=""></div></div>
    </div>

    <div class="grid-item">
        <img src="">
    </div>
</div>

关于css - 如何在网格中的列间隙区域内绘制分隔线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53693254/

相关文章:

html - 多列 - HTML

css - 在 CSS Grid 中使用带隐式行的负整数

javascript - 进度条根据倒计时

css - React native iOS 中的垂直居中自定义字体

jquery - 语义 UI 不呈现文本

css - 突出显示 CSS 网格

css - 响应式 CSSGrid 和悬停问题

javascript - ScrollTo 居中到没有 div 的网站

jquery - 添加 div 但让它们留在视口(viewport)内

css - 是否可以将 CSS 样式应用于列内的整行?