如何区分两天之间的日期

时间:2015-01-29 12:19:40

标签: javascript jquery css css3

我试图区分具有不同背景颜色的两个日期之间的日期,如何做到这一点? 在悬停任何日期时,我想更改所选日期之间日期的背景颜色。 我的代码在这里http://jsfiddle.net/sureshpattu/t739t99a/
我正在尝试做这样的事情http://codepen.io/davidkpiano/full/wBGjMr/

.pika-single {
    z-index: 9999;
    display: block;
    position: relative;
    width: 320px;
    padding: 8px;
    color: #333;
    background: #fff;
    border: 1px solid #ccc;
    border-bottom-color: #bbb;
    font-family: inherit;
}

.pika-single.is-hidden {
    display: none;
}

.pika-single.is-bound {
    position: absolute;
    box-shadow: 0 5px 15px -5px rgba(0, 0, 0, .5);
}

.pika-title {
    position: relative;
    text-align: center;
}

.pika-label {
    display: inline-block;
    *display: inline;
    position: relative;
    z-index: 9999;
    overflow: hidden;
    margin: 0;
    padding: 5px 3px;
    font-size: 16px;
    line-height: 20px;
    font-weight: bold;
    background-color: #fff;
}

.pika-title select {
    cursor: pointer;
    position: absolute;
    z-index: 9998;
    margin: 0;
    left: 0;
    top: 5px;
    filter: alpha(opacity=0);
    opacity: 0;
}

.pika-prev,
.pika-next {
    display: block;
    cursor: pointer;
    position: relative;
    outline: none;
    border: 0;
    padding: 0;
    width: 20px;
    height: 30px;
    /* hide text using text-indent trick, using width value (it's enough) */
    text-indent: 20px;
    white-space: nowrap;
    overflow: hidden;
    background-color: transparent;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 75% 75%;
    opacity: .5;
    *position: absolute;
    *top: 0;
}

.pika-prev:hover,
.pika-next:hover {
    opacity: 1;
}

.pika-prev,
.is-rtl .pika-next {
    float: left;
    background-image: url('');
    *left: 0;
}

.pika-next,
.is-rtl .pika-prev {
    float: right;
    background-image: url('');
    *right: 0;
}

.pika-prev.is-disabled,
.pika-next.is-disabled {
    cursor: default;
    opacity: .2;
}

.pika-select {
    display: inline-block;
    *display: inline;
}

.pika-table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    border: 0;
}

.pika-table th,
.pika-table td {
    width: 14.285714285714286%;
    padding: 0;
}

.pika-table th {
    color: #999;
    font-size: 12px;
    line-height: 25px;
    font-weight: bold;
    text-align: center;
}

.pika-button {
    cursor: pointer;
    display: block;
    outline: none;
    border: 0;
    margin: 0;
    width: 100%;
    padding: 12px;
    color: #666;
    font-size: 14px;
    line-height: 15px;
    text-align: center;
    background: #fff;
    border: 1px solid rgba(204, 204, 204, 0.25);
}

.is-today .pika-button {
    color: #333;
    font-weight: bold;
}

.is-selected .pika-button {
    color: #fff;
    font-weight: bold;
    background: #ff4081;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}

.is-disabled .pika-button {
    pointer-events: none;
    cursor: default;
    color: #999;
    opacity: .3;
    background: #eee;
}

.pika-button:hover {
    color: #fff;
    background: #ff4081;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}

Html代码

<div class="pika-single is-bound">
    <table cellpadding="0" cellspacing="0" class="pika-table">
        <tbody>
        <tr>
            <td class="is-empty"></td>
            <td class="is-empty"></td>
            <td class="is-empty"></td>
            <td class="is-empty"></td>
            <td class="is-empty"></td>
            <td class="is-empty"></td>
            <td data-day="1" class="">
                <button class="pika-button" type="button">1</button>
            </td>
        </tr>
        <tr>
            <td data-day="2" class="">
                <button class="pika-button" type="button">2</button>
            </td>
            <td data-day="3" class="">
                <button class="pika-button" type="button">3</button>
            </td>
            <td data-day="4" class="is-selected">
                <button class="pika-button" type="button">4</button>
            </td>
            <td data-day="5" class="">
                <button class="pika-button" type="button">5</button>
            </td>
            <td data-day="6" class="">
                <button class="pika-button" type="button">6</button>
            </td>
            <td data-day="7" class="">
                <button class="pika-button" type="button">7</button>
            </td>
            <td data-day="8" class="">
                <button class="pika-button" type="button">8</button>
            </td>
        </tr>
        <tr>
            <td data-day="9" class="">
                <button class="pika-button" type="button">9</button>
            </td>
            <td data-day="10" class="">
                <button class="pika-button" type="button">10</button>
            </td>
            <td data-day="11" class="">
                <button class="pika-button" type="button">11</button>
            </td>
            <td data-day="12" class="">
                <button class="pika-button" type="button">12</button>
            </td>
            <td data-day="13" class="">
                <button class="pika-button" type="button">13</button>
            </td>
            <td data-day="14" class="">
                <button class="pika-button" type="button">14</button>
            </td>
            <td data-day="15" class="">
                <button class="pika-button" type="button">15</button>
            </td>
        </tr>
        <tr>
            <td data-day="16" class="">
                <button class="pika-button" type="button">16</button>
            </td>
            <td data-day="17" class="">
                <button class="pika-button" type="button">17</button>
            </td>
            <td data-day="18" class="">
                <button class="pika-button" type="button">18</button>
            </td>
            <td data-day="19" class="">
                <button class="pika-button" type="button">19</button>
            </td>
            <td data-day="20" class="">
                <button class="pika-button" type="button">20</button>
            </td>
            <td data-day="21" class="">
                <button class="pika-button" type="button">21</button>
            </td>
            <td data-day="22" class="">
                <button class="pika-button" type="button">22</button>
            </td>
        </tr>
        <tr>
            <td data-day="23" class="">
                <button class="pika-button" type="button">23</button>
            </td>
            <td data-day="24" class="">
                <button class="pika-button" type="button">24</button>
            </td>
            <td data-day="25" class="">
                <button class="pika-button" type="button">25</button>
            </td>
            <td data-day="26" class="">
                <button class="pika-button" type="button">26</button>
            </td>
            <td data-day="27" class="">
                <button class="pika-button" type="button">27</button>
            </td>
            <td data-day="28" class="">
                <button class="pika-button" type="button">28</button>
            </td>
            <td class="is-empty"></td>
        </tr>
        </tbody>
    </table>
</div>

2 个答案:

答案 0 :(得分:1)

由于您标记了JQuery,我提出类似的建议:http://jsfiddle.net/t739t99a/1/

$(".pika-button").hover(function() {
  var currentVal = parseInt($(this).parent('td').attr("data-day"));
  var selectedVal = parseInt($(".is-selected").attr("data-day"));

    if (currentVal > selectedVal) {
      var tmp = currentVal;
      currentVal = selectedVal;
      selectedVal = tmp;
    }   
    for (var i=currentVal; i<selectedVal; i++) {
        $("td[data-day='"+i+"']").addClass("between");   
    }
}, function() {
    $(".between").removeClass("between");
});

.between button {
    background-color: #908081;
}

答案 1 :(得分:0)

在戴维斯的例子中,他使用输入,因为如果他们被检查,你可以用css检查。 有了它,你可以做一个像日志:

所有日子都有白色背景。

.day {
 background: #fff
}

检查日期背景较暗。

.day:checked {
 background: rgba(0,0,0,0.2)
}

第一天检查后的所有日子都有透明背景。

.day:checked:nth-child(1) ~ .day {
 background: transparent;
}

第二天检查后的所有日子再次出现白色背景。

.day:checked:nth-child(2) ~ .day {
 background: white;
}

...我没有测试过这段代码,但它与大卫在你的例子中使用的内容非常相似。