淘宝搜索框研究报告

作者:heero 来源:heero博客 时间:2010-07-27 12:49:00 

在输入框里面预设一段提示文字,当焦点在输入框的时候清空这段文字,这在目前来说已经不是什么新鲜事了。淘宝的搜索框就用到了这样一种设计:

这种设计一般是用javascript监控了输入框的focus和blur事件:

<input type="text" id="q" value="请输入关键字" />
<script type="text/javascript">//<![CDATA[
$("#q").onfocus = function() {
  if ("请输入关键字" == this.value) {
    this.value = "";
  }
};
$("#q").onblur = function() {
  if ("" == this.value) {
    this.value = "请输入关键字";
  }
};
//]]></script>

这段代码有两个很明显的缺点:

  1. “请输入关键字”这段提示共出现了3次,一旦要改这段文字就得改3个地方,维护显得非常不便

  2. 为了性能优化,我们会把javascript部分放到页面末尾。然而,像门户网站首页这种代码量很大的页面,末尾的javascript很可能会延时1-2秒执行。在这段时间内,即使焦点在输入框内,提示文字也不会消失,用户需要手动删除这段文字再输入内容

淘宝的输入框则采取了另一种做法,它不把这段提示文字作为输入框的value值,而是放在另一个标签内,再用绝对定位把这段文字叠到输入框上:

从上面的代码可以看到,提示文字在label标签内,这样做有两个好处:

  1. 良好的结构性。既不是div不是span,对input的说明就应该用label

  2. 良好的用户体验。由于设置了for属性,当用户点击label的时候,就会自动focus到输入框。

javascript要控制的其实就是label的显示和隐藏,再也不需要管那段提示文字的内容了:

$("#q").onfocus = function() {
  $("label[for=q]")[0].style.display = 'none';
};
$("#q").onblur = function() {
  if ("" == this.value) {
    $("label[for=q]")[0].style.display = '';
  }
};

javascript是简洁了,但用户体验呢?在javascript执行前,那段提示文字也是无论如何都不会消失,用户也是想删掉这段文字,但是他们删不了,因为这些文字实际上并不在输入框内,而他们输入的内容会被提示文字挡住了。我个人认为这给用户带来了很大的疑惑。

标签:淘宝,搜索框
0
投稿

猜你喜欢

  • phpstudy apache开启ssi使用详解

    2023-05-25 08:04:44
  • css基础教程之序曲

    2008-07-23 12:40:00
  • MySQL列类型的选择与MySQL的查询效率

    2009-01-14 12:53:00
  • 简单触发器的使用 献给SQL初学者

    2011-09-30 11:27:49
  • 键盘上下键的操作代码(选择)

    2008-06-10 12:28:00
  • 技术性击倒与抬杠

    2009-02-12 12:28:00
  • 了解WEB页面工具语言XML(五)好处

    2008-09-05 17:19:00
  • 不同操作系统下的mysql数据库同步

    2008-12-22 14:41:00
  • VBScript中LBound函数和UBound函数的用法

    2008-06-27 13:02:00
  • 论标志的简洁性

    2009-10-27 16:05:00
  • Yahoo发布一款FireFox网站开发插件

    2007-09-23 16:11:00
  • js实现input+select组合 抛砖引玉

    2010-08-02 12:34:00
  • CSS网页布局避免滥用DIV元素

    2011-03-30 12:34:00
  • 那些看一眼就让你难忘的广告

    2007-09-21 19:46:00
  • 谦逊编程(翻译整理)

    2009-07-28 12:52:00
  • js 混淆加密工具代码

    2007-09-22 18:10:00
  • 重新认识ASP之后的我在想"是时候改变了"

    2008-05-08 13:10:00
  • javascript面向对象编程(二)

    2008-03-07 12:59:00
  • jQuery技巧

    2009-09-27 12:28:00
  • Firefox插件推荐:CSS Usage

    2009-10-26 18:44:00
  • asp之家 网络编程 m.aspxhome.com