源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

淘宝搜索框效果实现分析

  • 时间:2022-06-11 05:28 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:淘宝搜索框效果实现分析
淘宝的搜索框就用到了这样一种设计: [img]http://files.jb51.net/upload/201103/20110305234012459.png[/img] 这种设计一般是用javascript监控了输入框的focus和blur事件:
[u]复制代码[/u] 代码如下:
<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>
这段代码有两个很明显的缺点: [list=1] [*]“请输入关键字”这段提示共出现了3次,一旦要改这段文字就得改3个地方,[b]维护显得非常不便[/b]。[/*] [*]为了性能优化,我们会把javascript部分放到页面末尾。然而,像门户网站首页这种代码量很大的页面,末尾的javascript很可能会延时1-2秒执行。在这段时间内,即使焦点在输入框内,提示文字也不会消失,[b]用户需要手动删除这段文字再输入内容[/b]。[/*][/list] 淘宝的输入框则采取了另一种做法,它不把这段提示文字作为输入框的value值,而是放在另一个标签内,再用绝对定位把这段文字叠到输入框上: [img]http://files.jb51.net/upload/201103/20110305234107468.png[/img] 从上面的代码可以看到,提示文字在label标签内,这样做有两个好处: [list=1] [*]良好的结构性。既不是div不是span,[b]对input的说明就应该用label[/b]。[/*] [*]良好的用户体验。由于设置了[b]for属性[/b],当用户点击label的时候,就会自动focus到输入框。[/*][/list] javascript要控制的其实就是[b]label的显示和隐藏[/b],再也不需要管那段提示文字的内容了:
[u]复制代码[/u] 代码如下:
$("#q").onfocus = function() {   $("label[for=q]")[0].style.display = 'none'; }; $("#q").onblur = function() {   if ("" == this.value) {     $("label[for=q]")[0].style.display = '';   } };
javascript是简洁了,但用户体验呢?在javascript执行前,那段提示文字也是无论如何都不会消失,用户也是想删掉这段文字,但是他们删不了,因为这些文字实际上并不在输入框内,而他们输入的内容会被提示文字挡住了。我个人认为这给用户带来了很大的疑惑。 [img]http://files.jb51.net/upload/201103/20110305234151811.png[/img]
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部