jquery.placeholder.min.js让IE浏览器支持placeholder属性

描述:现在都是HTML5时代了,所有的浏览器都支持placeholder,唯独IE不支持。现在我们有了这款插件,IE下终于可以支持了! 

图片展示:

兼容浏览器:IE6+/Firefox/Google Chrome

各版本CDN地址:http://www.bootcdn.cn/jquery-placeholder/

GitHub源码及示例:https://github.com/mathiasbynens/jquery-placeholder

JS代码

<script type="text/javascript" src="http://cdn.bootcss.com/jquery/1.8.3/jquery.min.js"></script>
<script type="text/javascript" src="jquery.placeholder.min.js"></script>
<script type="text/javascript">
 $(document).ready(function(){
	 $('input').placeholder(); 
});
</script>

HTML代码:

<input type="text" id="" name="" placeholder="请输入用户名">


除了上面使用jquery插件之外还可以使用下面的方法,测试有效

<!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="http://cdn.bootcss.com/jquery/1.8.3/jquery.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>

相关阅读

用JavaScript解决Placeholder的IE8兼容问题

赞(52) 打赏
未经允许不得转载:优客志 » 前端设计
分享到:

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏