被忽略的jQuery中data()函数
2009-11-05 17:00
190 查看
无意间在jQuery官方的文档中发现了这个函数,自己确从来没有注意到,失败啊。
函数的文档说明如下:
返回元素上储存的相应名字的数据,可以用data(name, value)来设定。 如果jQuery集合指向多个元素,那将只返回第一个元素的对应数据。这个函数可以用于在一个元素上存取数据而避免了循环引用的风险。 jQuery.data是1.2.3版的新功能。你可以在很多地方使用这个函数,另外jQuery UI里经常使用这个函数。
有例子比较好。
这里我们用搜索框的默认提示文本的效果做演示。
源代码如下:
<script type="text/javascript"> 02. bindDefaultText($(":text"), "keywords");
03.
04. function bindDefaultText($obj, strDefaultValue) {
05. if ($obj.val() == "")
06. $obj.val(strDefaultValue);
07.
08. $obj.data("defaultText", strDefaultValue).focus(function() {
09. if ($(this).val() == $(this).data("defaultText"))
10. $(this).val("");
11. }).blur(function() {
12. if ($(this).val() == "")
13. $(this).val($(this).data("defaultText"));
14. });
15. }
16.</script>
观察源代码的话会发现,该方法没有在HTML中增加任何自定义的属性,而是把数据以隐藏的方式设置的,这样HTML代码就非常干净了,正如文档中所说,如果用于UI的效果设计的话,简直是再合适不过了。
函数的文档说明如下:
返回元素上储存的相应名字的数据,可以用data(name, value)来设定。 如果jQuery集合指向多个元素,那将只返回第一个元素的对应数据。这个函数可以用于在一个元素上存取数据而避免了循环引用的风险。 jQuery.data是1.2.3版的新功能。你可以在很多地方使用这个函数,另外jQuery UI里经常使用这个函数。
有例子比较好。
这里我们用搜索框的默认提示文本的效果做演示。
源代码如下:
<script type="text/javascript"> 02. bindDefaultText($(":text"), "keywords");
03.
04. function bindDefaultText($obj, strDefaultValue) {
05. if ($obj.val() == "")
06. $obj.val(strDefaultValue);
07.
08. $obj.data("defaultText", strDefaultValue).focus(function() {
09. if ($(this).val() == $(this).data("defaultText"))
10. $(this).val("");
11. }).blur(function() {
12. if ($(this).val() == "")
13. $(this).val($(this).data("defaultText"));
14. });
15. }
16.</script>
观察源代码的话会发现,该方法没有在HTML中增加任何自定义的属性,而是把数据以隐藏的方式设置的,这样HTML代码就非常干净了,正如文档中所说,如果用于UI的效果设计的话,简直是再合适不过了。
相关文章推荐
- 被忽略的jQuery中data()函数
- 使用jQuery中的each(data,function(){});函数
- jQuery的data函数使用遇到的坑
- Jquery几个比较实用,但又让很多人忽略的几个函数
- jquery的data函数定义、使用和修改
- jQuery的data函数使用遇到的坑
- 关于js深入理解:json作为函数参数 类似于jQuery的post函数,具有url,data ,和回调函数
- 学做jQuery中的data()函数
- jQuery源码分析之深入理解jQuery.data,jQuery._data以及data实例函数十八问
- jQuery.getJSON( url [, data ] [, success ] ) 中的回调函数参数不执行
- 学做jQuery中的data()函数
- jquery的bind,unbind,live,data这些函数
- jQuery对象data函数使用注意事项
- jQuery.data() 函数详解
- Jquery几个比较实用,但又让很多人忽略的几个函数
- jQuery.data() 函数详解
- jquery中ajax的dataType设置为html和text的区别。
- 关于jQuery的data()方法的了解
- jQuery中使用this作为函数入参
- jQuery-1.9.1源码分析系列(六) 延时对象续——辅助函数jQuery.when