пятница, 12 ноября 2010 г.

Что-то с датой в JavaScript

Недавно столкнулся с одной особенностью JavaScript, а точнее класса Date. Во всех известных мне языках программирования (и других языках) 01-01-2000 - это первое января двухтысячного года. В JavaScript - это первое февраля двухтысячного года.

Чтобы получить первое января нужно создавать объект Date так: new Date(2000, 0, 1). Соответственно от остальных месяцев тоже нужно отнять единицу, т.к. в конструкторе класса Date они нумеруются с 0 по 11.

суббота, 6 ноября 2010 г.

Осторожно, динамическая типизация JavaScript

Недавно возникла такая проблема - все браузеры, кроме Internet Explorer (чудеса случаются), получая параметра от элемента, считали этот параметр строкой, а не числом. Это происходило примерно в следующей ситуации:

for (var i = 0; i < objects.length; i++) //objects - строки таблицы, например
{
   objects[i].setAttribute('i', i); //i сейчас точно является числом
}

...

for (var i = 0; i < objects.length; i++) //objects - те же строки таблицы
{
   value[i] = objects[i].getAttribute('i') + 1; //что окажется в value[i]?
}

Internet Explorer в value[i] запишет 1, 2, 3 и т.д. Другие браузеры запишут туда 01, 11, 21 и т.д. Вроде, результат очевиден: к выражению содержащему только цифры прибавляется число в явном виде - должно получиться число. Однако это понимает только Internet Explorer.

Если возникнет подобный случай, сразу используйте функцию parseInt(objects[i].getAttribute('i')).

пятница, 5 ноября 2010 г.

Забавные комментарии в коде

//Mr. Compiler, please do not read this.

last = first; /* Biblical reference */

long long ago; /* in a galaxy far far away */

//Comment this later

//I am not sure if we need this, but too scared to delete.

$this->getSelect()->where('main_table.product_id = -1');//Mom, Dad... sorry

/* Logger */
private Logger logger = Logger.getLogger();
  
Комментарии взяты с сайта www.remobred.ru.

четверг, 4 ноября 2010 г.

Очень краткий курс AJAX

Основная идея AJAX - отправка запроса на сервер и получения ответа от него без перезагрузки текущей страницы. AJAX поддерживается всеми современными браузерами, поэтому устанавливать какие-либо дополнительные компоненты не потребуется. Если вы знаете JavaScript и PHP (или любой другой серверный язык), то можете считать, что уже на 90% знаете AJAX. Если не знаете, то изучайте.

Решим типичную для AJAX задачу - реализуем на сайте часы, показывающие время на сервере. Для этого при загрузке страницы нам нужно создать специальный объект JavaSctipt, который будет отправлять запрос на сервер и получать ответ от него:

var request = null; //Cпециальный объект
if (window.XMLHttpRequest)
{
   request = new XMLHttpRequest(); //Для всех браузеров, кроме IE
} 
else if (window.ActiveXObject) 
{
   request = new ActiveXObject("Microsoft.XMLHTTP"); //Для IE
}

UpdateTime(); //Запускаем обновление времени

function UpdateTime()
{
   //Проверяем готовность к отправке запроса
   if(request.readyState == 4 || request.readyState == 0)
   {
      //Указывает метод передачи, путь к скрипту и будет ли запрос выполнятся асинхронно
      request.open("GET", "script.php", true);

      //Отключаем кэширование результатов (для IE)
      request.setRequestHeader("If-Modified-Since", "Sat, 1 Jan 2000 00:00:00 GMT");

      //Назначаем функцию, обрабатывающую ответ от сервера
      request.onreadystatechange = function()
      {
         //Проверяем - получен ли ответ
         if(request.readyState == 4)
         {
            if(request.status == 200)
            {
               //Записываем ответ от сервера в div
               document.getElementById('divTimer').innerHTML = request.responseText;

               //Повторяем запрос через 500 миллисекунд
               setTimeout('UpdateTime()', 500);
            }
         }
      };

      //Отправляем запрос
      request.send(null);
   }
   else
   {
      //Если специальный объект был занят, повторяем запрос через 500 миллисекунд
      setTimeout('UpdateTime()', 500);
   }
}

В файле script.php получаем время:

<?php echo date('H-i-s'); ?>

На этом курс окончен.) Ещё раз хочу подчеркнуть - не важно какой язык используется на стороне сервера. В request.responseText окажется то, что вы увидите, введя адрес своего скрипта в браузер (например, www.site.ru/script.php).

среда, 3 ноября 2010 г.

Mozilla - баг div c размерами 100% и overflow auto

Если вам повезло, то вы не столкнулись с некорректным поведением браузера Mozilla Firefox по отношению к элементам с размерами 100% и overflow auto. А мне не повезло. Рассмотрим, что именно происходит:


На рисунке показано, что в Mozilla div увеличился и вышел за пределы страницы, полоса прокрутки в нём не появилась. В остальных браузерах элемент отображается правильно. Код страницы выглядит так:

<body>
   <table width="100%" height="100%">
      <tr>
         <td></td>
         <td width="300">
            <div id="d1" style="width: 100%; height: 100%; overflow: auto; border: solid;">
               Большой текст или большой дочерний элемент.
            </div>
         </td>
      </tr>
   </table>
</body>

Я долго искал решение в CSS, но не нашёл. Поэтому пришлось решать проблему через JavaScript. В моём случае было несколько div с обозначенной проблемой, поэтому код написан для любого количества элементов:

//Массив с id элементов, размер которых нужно контролировать
var resizes = new Array("d1", "d2", "d3");

//Функция для правильного изменения размеров
function AutoSize()
{
   if(IsMozilla())
   { 
      //Два цикла нужны для корректного изменения размеров
      //В противном случае элементы растягивают друг друга
      for (var i = 0; i < resizes.length; i++)
      {
         var obj = document.getElementById(resizes[i]);
         obj.style.height = '1px';
      }

      for (var i = 0; i < resizes.length; i++)
      {
         var obj = document.getElementById(resizes[i]);
         obj.style.height = obj.parentNode.offsetHeight;
      }
   }
}

//Функция для определения того, что сайт запущен в Mozilla
function IsMozilla()
{
   var brow = navigator.userAgent.toLowerCase();
   return (brow.indexOf("gecko") >= 0 && brow.indexOf("chrome") < 0  && brow.indexOf("safari") < 0);
}

Функцию AutoSize нужно вызвать при загрузке страницы и изменении её размера:

<body onLoad="AutoSize();" onResize="AutoSize();">

Пока с этим кодом у меня никаких проблем не было. Всё исправно работает.

вторник, 2 ноября 2010 г.

Проект write2know - поиск совместными усилиями

Сидел я как-то вечером за своим новым ноутбуком - спокойно работал над сайтом. Вдруг, звонит мне директор нашей компании и спрашивает - знаю ли я Delphi. Большую часть времени я программировал на C# и Delphi не знаю, но он всё-равно сказал мне прийти на совещание в начале недели.

На совещании говорилось о созданиии программы для обсуждения поисковых запросов. Ничего не поняли? И я сразу не понял. Суть проекта была в следующем: пользователь вводит запрос, например, в Google, а другие пользователи видят этот запрос и могут комментировать его. Т.о. люди могут найти в комментариях то, чего не нашли в поисковике, или просто посмеяться.

Сначала я сделал приложение на C++ (которого тоже совсем не знал), т.к. требовалась максимальная кроссплатформенность, а .NET установлен далеко не у всех пользователей (Windows XP живее всех живых). Но такая реализация оказалась не совсем удобной. Поэтому пришлось ещё прилично поработать и сделать AJAX-сайт.


Сейчас сайт доступен по адресу write2know.ru.
Мои записи и на Я.ру — levelost!