• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > HTML5 Placeholder属性的详情介绍

HTML5 Placeholder属性的详情介绍

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含HTML5 ,Placeholder等相关知识,匿名希望在学习及工作中可以帮助到您
Placeholder(占位符) 是 HTML5 新增的一个 HTML 属性,用来对可输入字段的期望值提供提示信息,目前已经得到主流浏览器的广泛支持,使用方式非常简单:

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

该属性适用于 <textarea> 多行文本框和 type 属性值为 text, password, search, tel, url 或者 email 等的 <input>。

placeholder

自定义样式

如果想改变 placeholder 的默认呈现样式,应该使用 ::placeholder 伪元素选择器,不过当前还没有浏览器支持,因此只能根据不同浏览器的不同实现方式分别定义:

::-webkit-input-placeholder { /* Chrome/Safari/Opera */
  color: green;}::-moz-placeholder { /* Firefox 19+ */
  color: green;}:-ms-input-placeholder { /* IE 10+ 注意这里只有一个冒号 */
  color: green;}

为什么样式要分别定义呢,如果像下面这样组合到一起:

::-webkit-input-placeholder,::-moz-placeholder {
  color: green;}

不应该把针对不同浏览器的选择器写在一起,这样写会因为无法识别的选择器而造成这整个规则集被忽略(当然,像类似 IE 7 这种具有超强错误处理能力的浏览器除外,不过这里和 IE 7 没什么关系)。

Firefox 定义方式的改变

如果需要兼容老版本的 Firefox 浏览器,还需要添加下面这种只有一个冒号的样式规则:

:-moz-placeholder { /* Firefox 4 - 18 */
  color: green;}

因为从 Firefox 19 开始一个冒号的伪类定义方式 :-moz-placeholder 被废弃了,切换为两个冒号的伪元素定义方式。与此同时,它还添加了一个默认的 opacity: 0.54 不透明度样式,如果需要,可以覆盖掉该样式,否则文字是半透明的:

::-moz-placeholder {
  color: green;
  opacity: 1;}

伪类和伪元素

伪类和伪元素有什么区别呢?伪类可以理解为给某个元素添加了一个类,比如 :first-child 伪类,选择第一个子元素:

p:first-child {
  font-size: 16px;}

也可以理解为元素当前的状态,同样也可以通过添加一个真正的 class 来实现类似效果:

p.first-child {
  font-size: 16px;}

无论是伪类还是真正的类,样式都是直接添加到 <p> 元素上的。

而伪元素可以理解为添加了一个虚拟的元素。比如 p:before 伪元素,可以像下面这个伪代码这样理解:

<before>p:before</before><p>paragraph</p>

这里 <p> 元素和 p:before 可以理解为是两个不同的元素。如果被绕晕了,没关系,毕竟这不是本文的重点,更多伪元素与伪类的信息可以参考 Pseudo-classes - CSS | MDN 和 Pseudo-elements - CSS | MDN

关于伪类选择器引发的问题

因为 IE 浏览器使用的是伪类 :-ms-input-placeholder 选择器来定义 placeholder 的样式,实际上样式是作用于文本输入框的,如果另外还有针对文本输入框的选择器特殊性更高的样式规则,将会覆盖掉该样式,参考下面代码:

input:-ms-input-placeholder { /* 0, 0, 1, 1 */
  color: green;}#username { /* 0, 1, 0, 0 */
  color: blue;}

注释中的数字用来表示该选择器的特殊性。

上面两个样式规则当中使用 ID 选择器的特殊性更高,所以在 IE 10/11 中测试会看到 placeholder 显示为蓝色,与期望的有点不一样。同样使用伪类选择器的旧版本 Firefox 也会出现这个问题,因此,在书写样式的时候需要特别注意,实在搞不定,别忘了还有 !important 规则可以用。其它使用两个冒号的伪元素选择器的浏览器不会出现这个问题,例如:

input::-webkit-input-placeholder { /* 0, 0, 0, 2 */
  color: green;}#username { /* 0, 1, 0, 0 */
  color: blue;}

上面两个样式规则互相之间不会影响,使用 Chrome 测试 placeholder 的颜色为绿色。

关于选择器的特殊性可以参考拙作CSS选择器特殊性与重要性。

让行为保持一致

虽然样式是可以自定义了,不过在行为上还有些差异,在 Chrome 和 Firefox 中当文本输入框输入内容时 placeholder 才会消失,清除内容时又会显示出来;而在 IE 中则是当文本输入框获取焦点时 placeholder 就消失了,失去焦点同时没有输入内容时才会重新显示。如果希望在 Chrome 和 Firefox 等浏览器中实现获取焦点就消失的效果,可以借助 :focus 伪类选择器来将 placeholder 的文本颜色设置为透明:

:focus::-webkit-input-placeholder {
  color: transparent;}

当文本输入框获取焦点时,placeholder 的颜色被设置为透明,感官上就好像消失一样。

JavaScript

获取或者修改 placeholder 的内容直接获取或者修改对应文本输入框的 placeholder 属性的值就行了:

$('input').attr('placeholder', 'Please enter your name');

So easy,妈妈再也不用担心我写代码了。不过,想要像普通 DOM 元素那样通过 javaScript 获取伪元素对象直接操作估计很难,目前可以使用 window.getComputedStyle() 方法来得到其样式属性,该方法的第二个参数是一个伪元素:

window.getComputedStyle(document.getElementById('username'),
  '::-moz-placeholder').getPropertyValue('color'); // "rgb(0, 255, 0)"

如果要通过 JavaScript 来修改 placeholder 伪元素的样式的话比较好的一种方式是预先定义好几种不同的样式:

.style-1::-moz-placeholder {
  color: green;}.style-2::-moz-placeholder {
  color: red;}

然后通过切换文本输入框的 class 属性来实现修改样式的目的:

$('input').addClass('style-2').removeClass('style-1');

另外也可以通过直接添加样式规则来实现。

Polyfill

对于不支持该属性的浏览器,会简单地忽略掉。原则上,placeholder 仅仅是用来对期望的输入起个提示的作用,对于不支持的浏览器在可用性上不受任何影响。如果需要兼容,那么应该使用特性检测的方式,针对不支持的浏览器使用 Polyfill,对于支持的浏览器来说,原生的当然是最好。

判断浏览器是否支持 <input> 元素的 placeholder 属性,可以引入 Modernizr 库来判断:

if (!Modernizr.input.placeholder) {
  // 做点什么事}

也可以自己写判断,简单易行的办法就是生成一个 <input> 元素对象,并判断该元素对象是否具有 placeholder 属性:

'placeholder' in document.createElement('input')

同理,对于 <textarea> 元素也是一样:

'placeholder' in document.createElement('textarea')

另外,Opera Mini 明明不支持 placeholder 属性,却装成自己很懂的样子。这时候可以使用客户端检测技术来将之排除掉,Opera Mini 的 window 对象包含一个 operamini 对象:

({}).toString.call(window.operamini) === '[object OperaMini]'

结合起来就是这样:

if (!('placeholder' in document.createElement('input'))  || ({}).toString.call(window.operamini) === '[object OperaMini]') {
  // 做点什么事}

在编写 Polyfill 的时候应该尽量与原生功能保持一致,我这里选择向 IE 的方式看齐,即当文本输入框获取或失去焦点的时候处理 placeholder 是否显示,将文本输入框的 value 值设置为 placeholder 的值来模拟显示 placeholder 的状态。再添加上事件处理程序,当文本输入框获取焦点时如果 value 的值为 placeholder 则清空文本输入框;当文本输入框失去焦点时如果 value 值为空则将 placeholder 的内容赋给它,同时当 placeholder 显示的时候应该给文本输入框添加一个 class="placeholder" 用来设置样式以区别是显示的 placeholder 和还是显示的普通 value:

// 做点什么事$('input[placeholder]').on('focus', function() {
  var $this = $(this);
  if (this.value === $this.attr('placeholder') && $this.hasCl
  


 

您可能想查找下面的文章:

  • HTML5的本地存储
  • Define charset for HTML5 Doctype
  • HTML5 canvas如何绘制动态径向渐变
  • 如何使用HTML5 Canvas绘制动态线性渐变
  • HTML5 canvas如何实现马赛克的淡入淡出效果(代码)
  • HTML5 canvas中如何绘制图像
  • 如何使用HTML5 canvas实现图像的马赛克
  • html5 canvas实现简单的双缓冲
  • HTML5 Canvas 图形组合是如何实现的?附代码
  • HTML5 figure标签是什么意思?HTML5 figure标签的使用方法详解

相关文章

  • 2018-12-03随着HTML5的发展和微信应用号的出现,如何看待未来移动开发着的定位?
  • 2018-12-03移动端HTML5模拟长按删除事件(附代码)
  • 2018-12-03有关优化策略的文章推荐10篇
  • 2018-12-03HTML5地理定位实例_html5教程技巧
  • 2018-12-03用canvas+gif.js实现数字雨头像的方法
  • 2018-12-03HTML5之SVG 2D入门6—视窗坐标系与用户坐标系及变换概述_html5教程技巧
  • 2018-12-03怎样自定义并使用websocket子协议?
  • 2018-12-03html5画布旋转效果示例_html5教程技巧
  • 2018-12-03新增HTML5的八类INPUT输入
  • 2017-08-06简单介绍HTML5中的文件导入

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • a 标签为什么能够包含块级元素?
    • HTML5表单属性教程实例
    • HTML5 Canvas旋转动画的2个代码例子(一个旋转的太极图效果)
    • 5个好用的H5速查手册
    • 分享用canvas实现水流和水池动画的代码
    • Canvas跨域的解决方案介绍
    • html5中关于新增的几个背景属性和文本属性介绍
    • HTML5中新标签和常用标签详解_html5教程技巧
    • 如何自定义video播放器样式?
    • android支付宝客户端html5网页偶尔无法自动关闭问题

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有