欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-29 23:30:16
代码如下:

代码如下:


<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "https://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<html xmlns="https://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>