淘宝搜索框效果实现分析_javascript技巧
程序员文章站
2022-04-10 23:21:23
...
淘宝的搜索框就用到了这样一种设计:
这种设计一般是用javascript监控了输入框的focus和blur事件:
$("#q").onfocus = function() {
$("label[for=q]")[0].style.display = 'none';
};
$("#q").onblur = function() {
if ("" == this.value) {
$("label[for=q]")[0].style.display = '';
}
};
javascript是简洁了,但用户体验呢?在javascript执行前,那段提示文字也是无论如何都不会消失,用户也是想删掉这段文字,但是他们删不了,因为这些文字实际上并不在输入框内,而他们输入的内容会被提示文字挡住了。我个人认为这给用户带来了很大的疑惑。
这种设计一般是用javascript监控了输入框的focus和blur事件:
复制代码 代码如下:
这段代码有两个很明显的缺点:
- “请输入关键字”这段提示共出现了3次,一旦要改这段文字就得改3个地方,维护显得非常不便。
- 为了性能优化,我们会把javascript部分放到页面末尾。然而,像门户网站首页这种代码量很大的页面,末尾的javascript很可能会延时1-2秒执行。在这段时间内,即使焦点在输入框内,提示文字也不会消失,用户需要手动删除这段文字再输入内容。
淘宝的输入框则采取了另一种做法,它不把这段提示文字作为输入框的value值,而是放在另一个标签内,再用绝对定位把这段文字叠到输入框上:
从上面的代码可以看到,提示文字在label标签内,这样做有两个好处:
- 良好的结构性。既不是div不是span,对input的说明就应该用label。
- 良好的用户体验。由于设置了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执行前,那段提示文字也是无论如何都不会消失,用户也是想删掉这段文字,但是他们删不了,因为这些文字实际上并不在输入框内,而他们输入的内容会被提示文字挡住了。我个人认为这给用户带来了很大的疑惑。
上一篇: 求一些关于php扩展开发的资料
推荐阅读
-
JavaScript编程开发中jquery搜索框效果实现方法
-
基于JavaScript实现百度搜索框效果
-
JavaScript实现百度搜索框效果
-
Javascript小案例(一):仿淘宝搜索框用户输入事件的实现
-
JavaScript编程开发中jquery搜索框效果实现方法
-
JS仿淘宝实现的简单滑动门效果代码_javascript技巧
-
纯js实现遮罩层效果原理分析_javascript技巧
-
javascript实现的textarea运行框效果代码 不用指定id批量指定_javascript技巧
-
javascript实现ecshop搜索框键盘上下键切换控制_javascript技巧
-
JavaScript实现百度搜索框效果