任何元素上的中心叠加微调器

时间:2015-04-02 13:32:07

标签: html css

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

我创造了我当前进步的这个方面,但是我被困住了,我似乎无法将微调器放在父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。我希望能够将此类分配给大多数元素并查看微调器。

有什么建议吗?

3 个答案:

答案 0 :(得分:2)

请更新此css

.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;
    height: 1em;
    left: 50%;
    margin: 0 auto;
    overflow: visible;
    position: absolute;
    top: 50%;
    width: 1em;
    z-index: 9999;
}
.u-loading{position:relative}

答案 1 :(得分:1)

试试这个

.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;
    height: 1em;
    left: 50%;
    margin: 0 auto;
    overflow: visible;
    position: absolute;
    top: 50%;
    width: 1em;
    z-index: 9999;
}

答案 2 :(得分:0)

目前您的微调器位于display: inline-block

如果您想将其居中于其父级,则可以将其样式更改为display: block以及margin: auto