функция (blurClass) НЕ РАБОТАЕТ В IE - PullRequest
0 голосов
/ 23 марта 2010

Я не могу заставить этот плагин нормально работать в IE ....

Посетите мою домашнюю страницу и посмотрите на огромное поле поиска сверху ...

www.naturalskin.com

Каждый раз, когда я обновляю экран, «размытие» теряет свою функцию, и я застреваю с текстом .....

Вот скрипт, который я размещаю на внешней странице js: http://www.naturalskin.com/src/js/javascript/batches.js

jQuery.fn.hint = function (blurClass) {
  if (!blurClass) { 
    blurClass = 'blur';
  }

  return this.each(function () {
    // get jQuery version of 'this'
    var $input = jQuery(this),

    // capture the rest of the variable to allow for reuse
      title = $input.attr('title'),
      $form = jQuery(this.form),
      $win = jQuery(window);

    function remove() {
      if ($input.val() === title && $input.hasClass(blurClass)) {
        $input.val('').removeClass(blurClass);
      }
    }

    // only apply logic if the element has the attribute
    if (title) { 
      // on blur, set value to title attr if text is blank
      $input.blur(function () {
        if (this.value === '') {
          $input.val(title).addClass(blurClass);
        }
      }).focus(remove).blur(); // now change all inputs to title

      // clear the pre-defined text when form is submitted
      $form.submit(remove);
      $win.unload(remove); // handles Firefox's autocomplete
    }
  });
};

Эрик

1 Ответ

0 голосов
/ 24 марта 2010

попробуйте bind('blur',function(){}) вместо .blur (function () {});

Также используйте функцию триггера ('blur') вместо blur ();

Отредактировано

$input.bind('blur',function () {
        if (this.value === '') {
          $input.val(title).addClass(blurClass);
        }
      }).focus(remove).trigger('blur');

также хороший совет, если вы используете ajax в любое время, используйте .live () вместо .bind (); как это будет искать новые записи ...

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...