• placeholder的ie兼容性问题


    在html中引用以下的js文件,且在样式文件里这样写:input,textarea{color:#999;}        input:focus,textarea:focus{color:#333;}

    我这里仅仅是简单的用全局样式这样写了,假设你不想全部的input框都有提示,能够给须要的input特定的类,比方:.txt{color:#999;}   .txt:focus{color:#333;}

    (function($) {

     /**
      * Spoofs placeholders in browsers that don't support them (eg Firefox 3)
      *
      * Copyright 2011 Dan Bentley
      * Licensed under the Apache License 2.0
      *
      * Author: Dan Bentley [github.com/danbentley]
      */

     // Return if native support is available.
     if ("placeholder" in document.createElement("input")) return;

     $(document).ready(function(){
      $(':input[placeholder]').not(':password').each(function() {
       setupPlaceholder($(this));
      });

      $(':password[placeholder]').each(function() {
       setupPasswords($(this));
      });
       
      $('form').submit(function(e) {
       clearPlaceholdersBeforeSubmit($(this));
      });
     });

     function setupPlaceholder(input) {

      var placeholderText = input.attr('placeholder');

      setPlaceholderOrFlagChanged(input, placeholderText);
      input.focus(function(e) {
       if (input.data('changed') === true) return;
       if (input.val() === placeholderText) input.val('');
      }).blur(function(e) {
       if (input.val() === '') input.val(placeholderText);
      }).change(function(e) {
       input.data('changed', input.val() !== '');
      });
     }

     function setPlaceholderOrFlagChanged(input, text) {
      (input.val() === '') ? input.val(text) : input.data('changed', true);
     }

     function setupPasswords(input) {
      var passwordPlaceholder = createPasswordPlaceholder(input);
      input.after(passwordPlaceholder);

      (input.val() === '') ? input.hide() : passwordPlaceholder.hide();

      $(input).blur(function(e) {
       if (input.val() !== '') return;
       input.hide();
       passwordPlaceholder.show();
      });
       
      $(passwordPlaceholder).focus(function(e) {
       input.show().focus();
       passwordPlaceholder.hide();
      });
     }

     function createPasswordPlaceholder(input) {
      return $('<input>').attr({
       placeholder: input.attr('placeholder'),
       value: input.attr('placeholder'),
       id: input.attr('id'),
       readonly: true
      }).addClass(input.attr('class'));
     }

     function clearPlaceholdersBeforeSubmit(form) {
      form.find(':input[placeholder]').each(function() {
       if ($(this).data('changed') === true) return;
       if ($(this).val() === $(this).attr('placeholder')) $(this).val('');
      });
     }
    })(jQuery);

  • 相关阅读:
    时统设备简介和标准汇总
    html页面元素铺满屏幕
    JavaScript之单线程
    JavaScript 内存模型
    数据-内存-变量
    python+selenium2自动化---通过js脚本给时间控件赋值
    Linux常用命令---文件创建、查找
    python+selenium2自动化---使用pytesseract和Pillow实现验证码识别
    python+selenium2自动化---屏幕截图
    Linux常用命令---find
  • 原文地址:https://www.cnblogs.com/wgwyanfs/p/7065603.html
Copyright © 2020-2023  润新知