bootstrap data与jquery .data


Posted in Javascript onJuly 07, 2014

jquery官网对.data函数描述是:在匹配元素上存储任意相关数据 或 返回匹配的元素集合中的第一个元素的给定名称的数据存储的值。

存储键值(key/value):

$("body").data("foo", 52);

$("body").data("bar", { myType: "test", count: 40 });

$("body").data({ baz: [ 1, 2, 3 ] });

 
  取键值
 

$("body").data("foo"); // 52

$("body").data(); // { foo: 52, bar: { myType: "test", count: 40 }, baz: [ 1, 2, 3 ] }

以上这些都很容易掌握和理解,今天在看bootstrap 的弹窗掩码的时候遇到了这样一段代码让我产生了疑惑

$(document).on('click.modal.data-api', '[daTa-toggle="modal"]', function (e) {
  alert($(this).data().toggle) //这行是我加入的代码 打印的值是modal
  var $this = $(this)
   , href = $this.attr('href')
   , $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
   , option = $target.data('modal') ? 'toggle' : $.extend({ remote:!/#/.test(href) && href }, $target.data(), $this.data())  
  e.preventDefault()
  $target
   .modal(option)
   .one('hide', function () {
    $this.focus()
   })
 })

代码中的三目运算符 $target.data('modal')?'toggle' : $.extend({ remote:!/#/.test(href) && href }, $target.data(), $this.data())

是判断窗口是否是第一次渲染 。第一次渲染窗口的时候执行了

option = $.extend({ remote:!/#/.test(href) && href }, $target.data(), $this.data()) //结果是 option= {remote: false,toggle: "modal"}

$target.data()是空对象{} ,$this.data()值是{toggle: "modal"} 。这里不经要问 $this.data() 的返回值哪来的

看了下html代码,刚好与被绑定click方法的dom对象的属性值一样,以下是被绑定的dom对象的html代码

<a href="#myModal" rel="external nofollow" rel="external nofollow" role="button" class="btn" data-toggle="modal">Launch demo modal</a>

我加入的代码alert($(this).data().toggle)打印的值是modal ,所以这里只能是jquery做的文章,于是我研究了jquery的源码发现果然真是 !

以下是jQuery.fn.data函数中的部分代码 , 当key未定义也就是调用 .data() 未传参数时会将属性名为data-开头的键值对存入匹配元素上。

本例中<a href="#myModal" rel="external nofollow" rel="external nofollow" role="button" class="btn" data-toggle="modal">Launch demo modal</a>,将{toggle:"modal"}键值对存入

有兴趣的同学可以去试调以下jquery代码

// Gets all values
    if ( key === undefined ) {
      if ( this.length ) {
        data = jQuery.data( elem );
        if ( elem.nodeType === 1 && !jQuery._data( elem, "parsedAttrs" ) ) {
          attrs = elem.attributes;
          for ( ; i < attrs.length; i++ ) {
            name = attrs[i].name;
            if ( name.indexOf("data-") === 0 ) {
              name = jQuery.camelCase( name.slice(5) );

              dataAttr( elem, name, data[ name ] );
            }
          }
          jQuery._data( elem, "parsedAttrs", true );
        }
      }
      return data;
    }

我再去详细阅读了jquery官网的帮助文档有如下一段话
HTML5 data-* Attributes(HTML5 data-* 属性)
从jQuery 1.4.3起, HTML 5 data- 属性 将自动被引用到jQuery的数据对象中。嵌入式破折号处理属性( attributes)的方式在 jQuery 1.6 中已经改变,以使之符合W3C HTML5 规范.

举个例子, 给定下面的HTML:

<div data-role="page" data-last-value="43" data-hidden="true" data-options='{"name":"John"}'></div>

下面所有的 jQuery 代码都能运行。

$("div").data("role") === "page";
$("div").data("lastValue") === 43;
$("div").data("hidden") === true;
$("div").data("options").name === "John";
Javascript 相关文章推荐
D3.js封装文本实现自动换行和旋转平移等功能
Oct 14 Javascript
js addDqmForPP给标签内属性值加上双引号的函数
Dec 24 Javascript
js oncontextmenu事件使用详解
Mar 25 Javascript
JavaScript实现获取远程的html到当前页面中
Mar 26 Javascript
jQuery实现返回顶部按钮和scroll滚动功能[带动画效果]
Jul 05 jQuery
vue移动端UI框架实现QQ侧边菜单组件
Mar 09 Javascript
vue单页开发父子组件传值思路详解
May 18 Javascript
vue-router路由懒加载的实现(解决vue项目首次加载慢)
Aug 28 Javascript
jquery.pager.js实现分页效果
Jul 29 jQuery
5分钟快速看懂ES6中的反射与代理
Dec 19 Javascript
详解vue beforeEach 死循环问题解决方法
Feb 25 Javascript
vue 判断两个时间插件结束时间必选大于开始时间的代码
Nov 04 Javascript
函数式 JavaScript(一)简介
Jul 07 #Javascript
5款JavaScript代码压缩工具推荐
Jul 07 #Javascript
jquery easyui使用心得
Jul 07 #Javascript
Node.js与PHP、Python的字符处理性能对比
Jul 06 #Javascript
我的Node.js学习之路(四)--单元测试
Jul 06 #Javascript
我的Node.js学习之路(三)--node.js作用、回调、同步和异步代码 以及事件循环
Jul 06 #Javascript
我的Node.js学习之路(二)NPM模块管理
Jul 06 #Javascript
You might like
PHP 分页类(模仿google)-面试题目解答
2009/09/13 PHP
php线性表顺序存储实现代码(增删查改)
2012/02/16 PHP
使用Smarty 获取当前日期时间和格式化日期时间的方法详解
2013/06/18 PHP
php number_format() 函数通过千位分组来格式化数字的实现代码
2013/08/06 PHP
PHP入门之常量简介和系统常量
2014/05/12 PHP
php简单定时执行任务的实现方法
2015/02/23 PHP
PHP中strncmp()函数比较两个字符串前2个字符是否相等的方法
2016/01/07 PHP
JavaScript 给汉字排序实例代码
2008/06/28 Javascript
jquery遍历input取得input的name
2009/04/27 Javascript
基于jsTree的无限级树JSON数据的转换代码
2010/07/27 Javascript
IE下js调试工具Companion.JS
2010/10/15 Javascript
详解jquery uploadify 上传文件
2013/11/09 Javascript
JS获取月的最后一天与JS得到一个月份最大天数的实例代码
2013/12/16 Javascript
jQuery焦点控制图层展示延迟隐藏的方法
2015/03/09 Javascript
浅谈JavaScript字符串拼接
2015/06/25 Javascript
详解网站中图片日常使用以及优化手法
2017/01/09 Javascript
Node.js环境下Koa2添加travis ci持续集成工具的方法
2017/06/19 Javascript
详解React Native开源时间日期选择器组件(react-native-datetime)
2017/09/13 Javascript
VUE子组件向父组件传值详解(含传多值及添加额外参数场景)
2020/09/01 Javascript
vscode+gulp轻松开发小程序的完整步骤
2020/10/18 Javascript
python目录与文件名操作例子
2016/08/28 Python
Anaconda多环境多版本python配置操作方法
2017/09/12 Python
python使用pymongo操作mongo的完整步骤
2019/04/13 Python
keras实现theano和tensorflow训练的模型相互转换
2020/06/19 Python
sublime3之内网安装python插件Anaconda的流程
2020/11/10 Python
阿迪达斯德国官方网站:adidas德国
2017/07/12 全球购物
墨西哥巴士车票在线购买:ClickBus
2018/03/27 全球购物
罗马尼亚在线杂货店:Pilulka.ro
2019/09/28 全球购物
Kiwi.com中国:找到特价机票并发现新目的地
2019/10/27 全球购物
Python使用openpyxl复制整张sheet
2021/03/24 Python
销售高级职员求职信
2013/10/29 职场文书
公司企业表扬信
2014/01/11 职场文书
货车司机岗位职责
2014/03/18 职场文书
小学英语教师先进事迹
2014/05/28 职场文书
i7 6700处理器相当于i5几代
2022/04/19 数码科技
详解Mysql事务并发(脏读、不可重复读、幻读)
2022/04/29 MySQL