html - 在任何元素上居中叠加微调器

标签 html css

我正在尝试创建一个微调器类,当分配给任何元素时,它应该显示一个微调器覆盖并居中。

我创建了当前进度的这个 jfiddle,但我卡住了,我似乎无法将微调器置于父 div 的中心。

参见此处:Example

HTML:

<div class="u-loading">
<div class="address-container u-border-all">
    <input type="text"  class="address__textbox address__textbox--line u-border-bottom">
    <input type="text"  class="address__textbox address__textbox--house-no u-border-right">
    <input type="text" class="address__textbox address__textbox--street">
    <input type="text"  class="address__textbox address__textbox--line">
    <input type="text" class="address__textbox address__textbox--line">
    <input type="text" class="address__textbox address__textbox--line">
    <input type="text"  class="address__textbox address__textbox--postcode u-border-right u-border-top">
    <select class="address__textbox address__country u-border-top">
        <option value="Select a country" selected="selected" class="rps-placeholder">Select a country</option>
        <option value="England">England</option>
        <option value="Wales">Wales</option>
        <option value="Scotland">Scotland</option>
    </select>
</div>
</div>

CSS:

/*------------------------------------*\
    ##Loading
\*------------------------------------*/


/* Absolute Center CSS Spinner */
.u-loading {
    position: fixed;
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
    z-index: 9999;
}


.u-loading:not(:required):after {
    width: 100%;
    height: 100%;
    z-index: 9999;
    overflow: visible;
    position: relative;
    content: '';
    display: inherit;
    font-size: 10px;
    width: 1em;
    height: 1em;
    margin: 0 auto;
    -webkit-animation: spinner 1500ms infinite linear;
    -moz-animation: spinner 1500ms infinite linear;
    -ms-animation: spinner 1500ms infinite linear;
    -o-animation: spinner 1500ms infinite linear;
    animation: spinner 1500ms infinite linear;
    border-radius: 0.5em;
    -webkit-box-shadow: rgba(0, 0, 0, 0.75) 1.5em 0 0 0, rgba(0, 0, 0, 0.75) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) 0 1.5em 0 0, rgba(0, 0, 0, 0.75) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.5) -1.5em 0 0 0, rgba(0, 0, 0, 0.5) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.75) 0 -1.5em 0 0, rgba(0, 0, 0, 0.75) 1.1em -1.1em 0 0;
    box-shadow: rgba(0, 0, 0, 0.75) 1.5em 0 0 0, rgba(0, 0, 0, 0.75) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) 0 1.5em 0 0, rgba(0, 0, 0, 0.75) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) -1.5em 0 0 0, rgba(0, 0, 0, 0.75) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.75) 0 -1.5em 0 0, rgba(0, 0, 0, 0.75) 1.1em -1.1em 0 0;
}

/* Animation */

@-webkit-keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}
@-moz-keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}
@-o-keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}
@keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

.u-border-all {
    border: solid black 2px;
}

.address-container {
    height: 200px;
    width: 200px;
}

我尝试了绝对位置,但这会影响主 div。我希望能够将此类分配给大多数元素并查看微调器。

有什么建议吗?

最佳答案

/*------------------------------------*\
    ##Loading
\*------------------------------------*/


/* Absolute Center CSS Spinner */
.u-loading {
    z-index: 9999;
}


.u-loading:not(:required):after {
    width: 100%;
    height: 100%;
    z-index: 9999;
    overflow: visible;
    position: relative;
    content: '';
    display: inherit;
    font-size: 10px;
    width: 1em;
    height: 1em;
    margin: 0 auto;
    -webkit-animation: spinner 1500ms infinite linear;
    -moz-animation: spinner 1500ms infinite linear;
    -ms-animation: spinner 1500ms infinite linear;
    -o-animation: spinner 1500ms infinite linear;
    animation: spinner 1500ms infinite linear;
    border-radius: 0.5em;
    -webkit-box-shadow: rgba(0, 0, 0, 0.75) 1.5em 0 0 0, rgba(0, 0, 0, 0.75) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) 0 1.5em 0 0, rgba(0, 0, 0, 0.75) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.5) -1.5em 0 0 0, rgba(0, 0, 0, 0.5) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.75) 0 -1.5em 0 0, rgba(0, 0, 0, 0.75) 1.1em -1.1em 0 0;
    box-shadow: rgba(0, 0, 0, 0.75) 1.5em 0 0 0, rgba(0, 0, 0, 0.75) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) 0 1.5em 0 0, rgba(0, 0, 0, 0.75) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) -1.5em 0 0 0, rgba(0, 0, 0, 0.75) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.75) 0 -1.5em 0 0, rgba(0, 0, 0, 0.75) 1.1em -1.1em 0 0;
}

/* Animation */

@-webkit-keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}
@-moz-keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}
@-o-keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}
@keyframes spinner {
    0% {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

.u-border-all {
    border: solid black 2px;
}

.address-container {
    height: 200px;
    width: 200px;
}


.u-loading:not(:required)::after {
    animation: 1500ms linear 0s normal none infinite running spinner;
    border-radius: 0.5em;
    box-shadow: 1.5em 0 0 0 rgba(0, 0, 0, 0.75), 1.1em 1.1em 0 0 rgba(0, 0, 0, 0.75), 0 1.5em 0 0 rgba(0, 0, 0, 0.75), -1.1em 1.1em 0 0 rgba(0, 0, 0, 0.75), -1.5em 0 0 0 rgba(0, 0, 0, 0.75), -1.1em -1.1em 0 0 rgba(0, 0, 0, 0.75), 0 -1.5em 0 0 rgba(0, 0, 0, 0.75), 1.1em -1.1em 0 0 rgba(0, 0, 0, 0.75);
    content: "";
    display: inherit;
    font-size: 10px;
    left: 50%;
    margin: 0 auto;
    overflow: visible;
    position: fixed;
    top: 50%;
    z-index: 9999;
    
    transform: translate(-50%, -50%);
}
.u-loading{position:relative}
<div class="u-loading">
<div class="address-container u-border-all">
    <input type="text"  class="address__textbox address__textbox--line u-border-bottom">
    <input type="text"  class="address__textbox address__textbox--house-no u-border-right">
    <input type="text" class="address__textbox address__textbox--street">
    <input type="text"  class="address__textbox address__textbox--line">
    <input type="text" class="address__textbox address__textbox--line">
    <input type="text" class="address__textbox address__textbox--line">
    <input type="text"  class="address__textbox address__textbox--postcode u-border-right u-border-top">
    <select class="address__textbox address__country u-border-top">
        <option value="Select a country" selected="selected" class="rps-placeholder">Select a country</option>
        <option value="England">England</option>
        <option value="Wales">Wales</option>
        <option value="Scotland">Scotland</option>
    </select>
</div>
</div>

关于html - 在任何元素上居中叠加微调器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29414268/

相关文章:

html - slider 上的淡入淡出动画不起作用(仅限 CSS3 和 html5)

html - 将 PSD 转换为网站

html - float 内联 block 和非 float block 之间的布局差异

html - 调整浏览器大小时 Div 不重新定位

javascript - 通过更改内容找到 div 的最小高度,这样下面的页面就不会跳来跳去

html - 如何根据其base64编码的背景数据比例为<img>设置宽度和高度?

java - 使用 jsp request.getContextPath() 使 eclipse 无法识别 css 文件

链接上的 jQuery 单击以启用加载图形

html - 如何在目录周围环绕文字

javascript - Jquery 1.8,检查元素是否隐藏