使用jQuery快速解决input中placeholder值在ie中无法支持的问题

转载 2015年11月20日 11:47:46
代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script type="text/javascript" src="js/jquery-1.4.2.min.js"></script>
<script type="text/javascript">

//第一种方法
$(document).ready(function(){
    var doc=document,inputs=doc.getElementsByTagName('input'),supportPlaceholder='placeholder'in doc.createElement('input'),placeholder=function(input){var text=input.getAttribute('placeholder'),defaultValue=input.defaultValue;
    if(defaultValue==''){
        input.value=text}
        input.onfocus=function(){
            if(input.value===text){this.value=''}};
            input.onblur=function(){if(input.value===''){this.value=text}}};
            if(!supportPlaceholder){
                for(var i=0,len=inputs.length;i<len;i++){var input=inputs[i],text=input.getAttribute('placeholder');
                if(input.type==='text'&&text){placeholder(input)}}}});

//第二种方法
$(function(){
if(!placeholderSupport()){   // 判断浏览器是否支持 placeholder
    $('[placeholder]').focus(function() {
        var input = $(this);
        if (input.val() == input.attr('placeholder')) {
            input.val('');
            input.removeClass('placeholder');
        }
    }).blur(function() {
        var input = $(this);
        if (input.val() == '' || input.val() == input.attr('placeholder')) {
            input.addClass('placeholder');
            input.val(input.attr('placeholder'));
        }
    }).blur();
};
})
function placeholderSupport() {
    return 'placeholder' in document.createElement('input');
}
</script>

</head>
<body>
<form>
  <label for="name">用户名:</label>
  <input type="text" placeholder="请输入用户名"/>
</form>
</body>
</html>

解决IE浏览器文本输入框不支持placeholder的问题

解决IE浏览器文本输入框不支持placeholder的问题
  • wendrewshay
  • wendrewshay
  • 2017年05月05日 09:41
  • 331

placeholder的ie兼容性问题

在html中引用下面的js文件,且在样式文件中这样写:input,textarea{color:#999;}        input:focus,textarea:focus{color:#333;...
  • sunny327
  • sunny327
  • 2015年07月23日 16:52
  • 1560

使用jQuery解决IE9以下无法支持input的placeholder的问题

placeholder是html5的新属性,可想而知,仅支持html5的浏览器才支持placeholder,目前最新的firefox、chrome、safari以及ie10都支持,ie6到ie9都不支...
  • cddcj
  • cddcj
  • 2016年09月08日 16:54
  • 1514

IE不兼容placeholder的解决方案

IE789的input输入框不支持placeholder,方案如下: 1. 如果没有password:  2. 如果有password: /** * @author hyyu 2016.1...
  • yu670538949
  • yu670538949
  • 2016年12月19日 19:56
  • 1019

jquery input placeholder支持兼容ie7,ie8

/* * jQuery placeholder, fix for IE6,7,8,9 * @author byh */ var JPlaceHolder = { //检测 _ch...
  • boyit0
  • boyit0
  • 2016年12月14日 09:47
  • 881

Ie9以下的input输入框placeholder属性兼容方案

.placeholder{ color:#999;}   //   兼容ie9的placeholder function isPlaceholder(){     var inpu...
  • qq_28307565
  • qq_28307565
  • 2017年06月20日 11:27
  • 147

完美解决IE不支持placeholder的问题

完美解决IE不支持placeholder的问题,placeholder属性在IE中,只有 IE11 支持。
  • QQ80583600
  • QQ80583600
  • 2017年03月16日 15:05
  • 3839

jquery修改输入框和文本域的placeholder

在项目中遇到输入框的重置按钮,重置的内容是需要把input输入框中的内容置空,并且显示placeholder的值; 如果使用$('input').val(' ');的方式不仅把输入框中的内容置空了,并...
  • xuexizhe88
  • xuexizhe88
  • 2017年08月23日 16:22
  • 809

placeholder在IE8中不显示,一种解决办法

做的一个查询页面,在IE10的基础上做的,input标签用到了placeholder属性。将页面放到IE8去显示,placeholder属性失效了。从网上查找了很多方法,最终采取使用JS的方式解决了兼...
  • qq_37421862
  • qq_37421862
  • 2017年07月21日 13:40
  • 575

用JavaScript解决Placeholder的IE8兼容问题

if( !('placeholder' in document.createElement('input')) ){           $('input[placeholder],textarea[...
  • wen_t
  • wen_t
  • 2016年02月26日 13:11
  • 2803
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用jQuery快速解决input中placeholder值在ie中无法支持的问题
举报原因:
原因补充:

(最多只允许输入30个字)