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 相关文章推荐
载入进度条 效果
Jul 08 Javascript
JQuery实现动态适时改变字体颜色的方法
Mar 10 Javascript
jQuery实现鼠标经过图片变亮其他变暗效果
May 08 Javascript
JavaScript中的函数嵌套使用
Jun 04 Javascript
javascript基础语法学习笔记
Jan 04 Javascript
Bootstrap每天必学之日期控制
Mar 07 Javascript
[原创]js实现保存文本框内容为本地文件兼容IE,chrome,火狐浏览器
Feb 14 Javascript
Angular6 用户自定义标签开发的实现方法
Jan 08 Javascript
JavaScript实现的弹出遮罩层特效经典示例【基于jQuery】
Jul 10 jQuery
微信小程序云函数使用mysql数据库过程详解
Aug 07 Javascript
详解Vue中的自定义指令
Dec 07 Vue.js
vue+elementUI动态增加表单项并添加验证的代码详解
Dec 17 Vue.js
函数式 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使用ob_start()实现图片存入变量的方法
2014/11/14 PHP
PHP生成条形图的方法
2014/12/10 PHP
Yii2表单事件之Ajax提交实现方法
2017/05/04 PHP
一段非常简单的让图片自动切换js代码
2006/11/10 Javascript
准确获得页面、窗口高度及宽度的JS
2006/11/26 Javascript
Jquery Select操作方法集合脚本之家特别版
2010/05/17 Javascript
jquery图片放大镜功能的实例代码
2013/03/26 Javascript
深入document.write()与HTML4.01的非成对标签的详解
2013/05/08 Javascript
js中的eventType事件及其浏览器支持性介绍
2013/11/29 Javascript
JavaScript设计模式之建造者模式介绍
2014/12/28 Javascript
js数组依据下标删除元素
2015/04/14 Javascript
angularjs学习笔记之三大模块(modal,controller,view)
2015/09/26 Javascript
Bootstrap编写导航栏和登陆框
2016/05/30 Javascript
浅谈时钟的生成(js手写简洁代码)
2016/08/20 Javascript
微信小程序网络请求wx.request详解及实例
2017/05/18 Javascript
javascript+html5+css3自定义提示窗口
2017/06/21 Javascript
基于node.js制作简单爬虫教程
2017/06/29 Javascript
微信小程序实现的涂鸦功能示例【附源码下载】
2018/01/12 Javascript
详解JavaScript事件循环机制
2018/09/07 Javascript
vue移动端城市三级联动组件使用详解
2019/07/26 Javascript
解决vue-cli项目开发运行时内存暴涨卡死电脑问题
2019/10/29 Javascript
浅谈Vue static 静态资源路径 和 style问题
2020/11/07 Javascript
python之Flask实现简单登录功能的示例代码
2018/12/24 Python
python实现贪吃蛇游戏
2020/03/21 Python
在python中求分布函数相关的包实例
2020/04/15 Python
详解基于python的图像Gabor变换及特征提取
2020/10/26 Python
亚洲最大的运动鞋寄售店:KicksCrew
2020/11/26 全球购物
计算机专业毕业生自我鉴定
2014/01/16 职场文书
《开国大典》教学反思
2014/04/19 职场文书
好学生评语大全
2014/05/05 职场文书
升旗仪式演讲稿
2014/05/08 职场文书
4s店销售经理岗位职责
2014/07/19 职场文书
销售员工作检讨书(推荐篇)
2014/10/18 职场文书
母亲节感言
2015/08/03 职场文书
Python使用psutil库对系统数据进行采集监控的方法
2021/08/23 Python
python turtle绘图
2022/05/04 Python