placeholder兼容性
类别:Web前端 浏览量:2421
时间:2015-8-25 placeholder兼容性
placeholder兼容性placeholder是html5新增的一个属性,当input或者textarea设置了该属性后,该值的内容将作为灰字提示显示在文本框中,当文本框获得焦点(或输入内容)时,提示文字消失。
但是在不支持html5的低版本的浏览器中,placeholder属性是无效的,例如ie9及以下的ie浏览器不兼容这个属性。下面介绍placeholder兼容性的处理
在页面添加如下脚本
$(function() {
// 如果不支持placeholder,用jQuery来完成
if(!isSupportPlaceholder()) {
// 遍历所有input对象, 除了密码框
$('input').not("input[type='password']").each(
function() {
var self = $(this);
var val = self.attr("placeholder");
input(self, val);
}
);
/* 对password框的特殊处理
* 1.创建一个text框
* 2.获取焦点和失去焦点的时候切换
*/
$('input[type="password"]').each(
function() {
var pwdField = $(this);
var pwdVal = pwdField.attr('placeholder');
var pwdId = pwdField.attr('id');
// 重命名该input的id为原id后跟1
pwdField.after('<input id="' + pwdId +'1" type="text" value='+pwdVal+' autocomplete="off" />');
var pwdPlaceholder = $('#' + pwdId + '1');
pwdPlaceholder.show();
pwdField.hide();
pwdPlaceholder.focus(function(){
pwdPlaceholder.hide();
pwdField.show();
pwdField.focus();
});
pwdField.blur(function(){
if(pwdField.val() == '') {
pwdPlaceholder.show();
pwdField.hide();
}
});
}
);
}
});
// 判断浏览器是否支持placeholder属性
function isSupportPlaceholder() {
var input = document.createElement('input');
return 'placeholder' in input;
}
// jQuery替换placeholder的处理
function input(obj, val) {
var $input = obj;
var val = val;
$input.attr({value:val});
$input.focus(function() {
if ($input.val() == val) {
$(this).attr({value:""});
}
}).blur(function() {
if ($input.val() == "") {
$(this).attr({value:val});
}
});
}
标签:jquery
您可能感兴趣
- Jquery中parent()和parents()
- jquery解析xml
- jquery unbind
- jquery中animate
- jQuery判断对象是否存在
- 2014-8-31
- 介绍几个jQuery实用函数
- jquery中serialize方法对空格的处理
- jquery五子棋javascript(原生JavaScript实现简单五子棋游戏)
- jquery中prop和attr的区别
- jQuery给动态添加的元素绑定事件
- jquery on绑定hover
- jquery实现在光标位置插入内容
- jQuery对象和DOM的相互转换
- jQuery如何跳出each循环
- jquery留言板代码(JavaScript实现留言板添加删除留言)
- 谢娜是得罪快乐大本营造型师了吗 全场被黑化(谢娜是得罪快乐大本营造型师了吗)
- 前《iLOOK》时装总监 《快乐大本营》御用造型师上线(快乐大本营御用造型师上线)
- 释小龙晒杀青照片 多重身份惹观众期待(释小龙晒杀青照片)
- 《九牛之人降魔传》开机 演员祁高坤化身九牛之人除魔卫道(九牛之人降魔传开机)
- 王铲铲的致富之路无限金币卡法攻略教学(王铲铲的致富之路无限金币卡法攻略教学)
- 文明6金币太少怎么办 文明6无限刷钱教程(文明6金币太少怎么办)
热门推荐
- dedecms搜索功能的实现(让DEDECMS自动内链起来的实现方法)
- docker容器启动原理(docker容器的原理分析)
- vue虚拟dom如何转换成真实dom的(vue中对虚拟dom的理解知识点总结)
- php class使用场景(php反射学习之不用new方法实例化类操作示例)
- textarea换行属性(处理textarea中的换行和空格)
- mysql流式查询(MySQL全面瓦解之查询的正则匹配详解)
- angular使用方法(Angular环境搭建及简单体验小结)
- 香港云服务器怎么那么火(如何选择便宜稳定的香港云服务器?)
- php验证码初始化教程交流(PHP token验证生成原理实例分析)
- sql server2012自动备份(SQL SERVER 2012数据库自动备份的方法)