Я переехал один год назад с классических языков OO, таких как Java на JavaScript. Следующий код определенно не рекомендуется (или даже не корректно) в Java:
if(dayNumber = getClickedDayNumber(dayInfo))
{
alert("day number found : " + dayNumber);
}
function getClickedDayNumber(dayInfo)
{
dayNumber = dayInfo.indexOf("fc-day");
if(dayNumber != -1) //substring found
{
//normally any calendar month consists of "40" days, so this will definitely pick up its day number.
return parseInt(dayInfo.substring(dayNumber+6, dayNumber+8));
}
else return false;
}
В принципе, я только выяснил, что могу назначить переменную значению в условии if if и сразу же проверить назначенное значение, как если бы оно было логическим.
Для более безопасной ставки я обычно разделяю это на две строки кода, назначая сначала, а затем проверяю переменную, но теперь, когда я нашел это, мне просто интересно, хороша ли практика или нет в глазах опытных разработчиков JavaScript