Как выполнить значение из элемента <td> - PullRequest
0 голосов
/ 16 января 2019

Я не знаком с JS, можете ли вы дать мне какие-либо советы. Так что в основном у меня есть календарь, который генерируется динамически. И мне нужно отметить текущий день, например, "красным". Вы можете использовать мой код для более подробной информации.

Когда я пытаюсь выполнить значение из этой таблицы, я получаю массив, который выглядит следующим образом ~> введите описание изображения здесь .

https://codepen.io/david_jons/pen/aPXeaK

<div id="calendar-container">
  <div id="calendar-header">
      <span id="calendar-month-year"></span>
  </div>
      <div id="calendar-dates">
  </div>
</div>

JS:

window.onload = function(){
    var d = new Date();
    var month_name = ['January','February','March','April','May','June','July','August','September','October','November','December'];
    var month = d.getMonth();
    var year = d.getFullYear();
    var first_date = month_name[month] + " " + 1 + " " + year;
    var tmp = new Date(first_date).toDateString();
    var first_day = tmp.substring(0, 3);
    var day_name = ['Sun','Mon','Tue','Wed','Thu','Fri','Sat'];
    var day_no = day_name.indexOf(first_day);
    var days = new Date(year, month+1, 0).getDate();
    var calendar = get_calendar(day_no, days);

    document.getElementById("calendar-month-year").innerHTML = month_name[month]+" "+year;
    document.getElementById("calendar-dates").appendChild(calendar);

    var tr = document.getElementById("calendar-dates");
    var tds = tr.getElementsByTagName("td");
    var current_date = d.getDate();
}

function get_calendar(day_no, days){
    var table = document.createElement('table');
    var tr = document.createElement('tr');

    //row for the day letters
    for(var c=0; c<=6; c++){
        var li = document.createElement('li');
        li.innerHTML = "SMTWTFS"[c];
        tr.appendChild(li);
    }
    table.appendChild(tr);

    //create 2nd row
    tr = document.createElement('tr');
    var c;
    for(c=0; c<=6; c++){
        if(c == day_no){
            break;
        }
        var td = document.createElement('td');
        td.innerHTML = "";
        tr.appendChild(td);
    }

    var count = 1;
    for(; c<=6; c++){
        var td = document.createElement('td');
        td.innerHTML = count;
        count++;
        tr.appendChild(td);
    }
    table.appendChild(tr);

    //rest of the date rows
    for(var r=3; r<=7; r++){
        tr = document.createElement('tr');
        for(var c=0; c<=6; c++){
            if(count > days){
                table.appendChild(tr);
                return table;
            }
            var td = document.createElement('td');
            td.innerHTML = count;
            count++;
            tr.appendChild(td);
        }
        table.appendChild(tr);
    }
    return table;
}

Ответы [ 2 ]

0 голосов
/ 16 января 2019

Вы можете перебрать коллекцию HTML, используя Array.prototype.filter, вызванный с коллекцией HTML в качестве контекста.

Может помочь следующий фрагмент:

var cells = document.getElementById("calendar-dates").getElementsByTagName("td");
var current_date = d.getDate();
var matchingElement = Array.prototype.filter.call(cells, function(cell) {
  return +current_date === +cell.textContent;
})[0];
matchingElement.style.backgroundColor = 'red';
0 голосов
/ 16 января 2019

По сути, вы должны проверить, совпадает ли текущая дата, которую вы вставляете, с сегодняшней (new Date()).

function isToday(day, month, year){
  const today = new Date();
  return today.getDate() === day && today.getMonth() === month &&     today.getFullYear()===year;
}

https://codepen.io/kwiniarski97/pen/magPKV?editors=1111

это можно сделать другими способами, это всего лишь один

...