让ie8实现placeholder属性效果,value值的默认颜色怎么设置才能和输入时的颜色不冲突?

clipboard.png

<ul><li><input type="text"  value="请输入用户名" onfocus="this.value=''" onblur="this.value='请输入用户名'"></li></ul>        

请问用上面这种方式,如果设置了value的默认颜色,怎么避免输入时的颜色不一样?

阅读 4.3k
2 个回答
<input  type="text"   name="搜索"  value="搜索" placeholder="搜索" id="selector"/>

这个placeholder在ff、chrome等浏览器支持修改样式

::-moz-placeholder{color:red;}              //ff
::-webkit-input-placeholder{color:red;}     //chrome,safari
:-ms-input-placeholder{color:red;}          //ie10          

然后判断一下 如果浏览器不支持placeholder(我这个例子只判断了ie8),再进行js模拟placeholder的操作

$(function(){
    if(!!navigator.userAgent.match(/MSIE 8.0/)){
            $('input[placeholder], textarea[placeholder]').each(function() {
                var input = $(this);
                if (input.val() === '' && input.attr("placeholder") !== ''){   
                    input.addClass("placeholder").val(input.attr('placeholder'));
                }

                input.focus(function() {
                    if (input.val() === input.attr('placeholder')) {
                        input.val('');
                    }
                });

                input.blur(function() {
                    if (input.val() === '' || input.val() === input.attr('placeholder')) {
                        input.val(input.attr('placeholder'));
                    }
                });
            });
    }
});

注释:
:text选择所有类型为text的input元素。
如果需要自定义样式,并且希望placeholder在所有浏览器下表现一致,可以通过利用label标签模拟一个placeholder的样式放到输入框上,当输入框获得焦点的时候,隐藏label,当输入框失去焦点的时候,显示label
根据以上的代码 你就可以设置placeholder这个classstyle

有一款插件,基于jq 叫placholder,你可以试一试

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏