IE678下placeholder效果,支持文本框和密码框

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了IE678下placeholder效果,支持文本框和密码框相关的知识,希望对你有一定的参考价值。

(function($) {
  var placeholderfriend = {
    focus: function(s) {
      s = $(s).hide().prev().show().focus();
      var idValue = s.attr("id");
      if (idValue) {
        s.attr("id", idValue.replace("placeholderfriend", ""));
      }
      var clsValue = s.attr("class");
      if (clsValue) {
        s.attr("class", clsValue.replace("placeholderfriend", ""));
      }
    }
  }

  //判断是否支持placeholder
  function isPlaceholer() {
    var input = document.createElement(‘input‘);
    return "placeholder" in input;
  }
  //不支持的代码
  if (!isPlaceholer()) {
    $(function() {

      var form = $(this);
      var elements = form.find("input[type=‘text‘][placeholder]");
      elements.each(function() {
        var s = $(this);
        var pValue = s.attr("placeholder");
          var sValue = s.val();
        if (pValue) {
          if (sValue == ‘‘) {
            s.val(pValue).css(‘color‘,‘#E0E0E0‘);
          }
        }
      });

      elements.focus(function() {
        var s = $(this);
        var pValue = s.attr("placeholder");
        var sValue = s.val();
        if (sValue && pValue) {
          if (sValue == pValue) {
            s.val(‘‘).css(‘color‘,‘#E0E0E0‘);
          }
        }
      });

      elements.blur(function() {
        var s = $(this);
        var pValue = s.attr("placeholder");
        var sValue = s.val();
        if (!sValue) {
          s.val(pValue);
        }
      });

      var element_em = form.find("input[type=‘email‘][placeholder]");
      element_em.each(function() {
        var s = $(this);
        var pValue = s.attr("placeholder");
      var sValue = s.val();
        if (pValue) {
          if (sValue == ‘‘) {
            s.val(pValue).css(‘color‘,‘#E0E0E0‘);
          }
        }
      });

      element_em.focus(function() {
        var s = $(this);
        var pValue = s.attr("placeholder");
    var sValue = s.val();
        if (sValue && pValue) {
          if (sValue == pValue) {
            s.val(‘‘).css(‘color‘,‘#E0E0E0‘);
          }
        }
      });

      element_em.blur(function() {
        var s = $(this);
        var pValue = s.attr("placeholder");
    var sValue = s.val();
        if (!sValue) {
          s.val(pValue);
        }
      });

      var elementsPass = form.find("input[type=‘password‘][placeholder]");
      elementsPass.each(function(i) {
        var s = $(this);
        var pValue = s.attr("placeholder");
        var sValue = s.val();
        s.val(sValue).css(‘color‘,‘#e0e0e0‘);
        if (pValue) {
          if (sValue == ‘‘) {
            var html = this.outerHTML || "";
            html = html.replace(/\s*type=([‘"])?password\1/gi, " type=text placeholderfriend").replace(/\s*(?:value|on[a-z]+|name)(=([‘"])?\S*\1)?/gi, " ").replace(/\s*placeholderfriend/, " placeholderfriend value=‘" + pValue + "‘ " + "onfocus=‘placeholderfriendfocus(this);‘ ");
            var idValue = s.attr("id");
            if (idValue) {
              s.attr("id", idValue + "placeholderfriend");

            }
            var clsValue = s.attr("class");
            if (clsValue) {
              s.attr("class", clsValue + "placeholderfriend");
            }
            s.hide();
            s.after(html);
          }
        }
      });

      elementsPass.blur(function() {
        var s = $(this);
        var sValue = s.val();
        if (sValue == ‘‘) {
          var idValue = s.attr("id");
          if (idValue) {
            s.attr("id", idValue + "placeholderfriend");
          }
          var clsValue = s.attr("class");
          if (clsValue) {
            s.attr("class", clsValue + "placeholderfriend");
          }
          s.hide().next().show();
        }
      });

    });
  }
  window.placeholderfriendfocus = placeholderfriend.focus;
})(jQuery);

以上是关于IE678下placeholder效果,支持文本框和密码框的主要内容,如果未能解决你的问题,请参考以下文章

jQuery placeholder插件 让IE也能够支持placeholder属性

placeholder插件兼容ie6.7.8,(支持密码框)

js解决IE89下placeholder的兼容问题

可以在文本框的placeholder=""插入搜索图标吗?

ie下不支持placeholder 用jquery来完成兼容

使IE支持placeholder