点评:大家可能会经常看到一些HTML里都带有data属性,这些都是HTML5的自定义属性,下面为大家简单介绍一下使用方法,希望对你有所帮助
大家可能会经常看到一些HTML里都带有data属性,这些都是HTML5的自定义属性,可以做很多事情,直接调用JS十分方便,虽然是HTML5的属性,但好在jQuery通用的,所以基本在所有浏览器里都是可以正常使用的,包括低版本的IE。下面为大家简单介绍一下使用方法:
nvDHTML5中文学习网 - HTML5先行者学习网1、简单使用
nvDHTML5中文学习网 - HTML5先行者学习网 nvDHTML5中文学习网 - HTML5先行者学习网
<div id="widget" data-text="123456"></div> nvDHTML5中文学习网 - HTML5先行者学习网
nvDHTML5中文学习网 - HTML5先行者学习网 nvDHTML5中文学习网 - HTML5先行者学习网
$(function(){ nvDHTML5中文学习网 - HTML5先行者学习网
var _widget= $("#widget").attr("data-text"); alert(_widget);//因为data-text="123456",所以打印出123456 nvDHTML5中文学习网 - HTML5先行者学习网
}) nvDHTML5中文学习网 - HTML5先行者学习网
nvDHTML5中文学习网 - HTML5先行者学习网2、配合$.fn.extend使用,编写插件
nvDHTML5中文学习网 - HTML5先行者学习网 nvDHTML5中文学习网 - HTML5先行者学习网
<div id="widget" data-widget-config="{effect:'click'}">这里是测试区域</div> nvDHTML5中文学习网 - HTML5先行者学习网
nvDHTML5中文学习网 - HTML5先行者学习网 nvDHTML5中文学习网 - HTML5先行者学习网
//插件扩展部分 nvDHTML5中文学习网 - HTML5先行者学习网
;(function($){ nvDHTML5中文学习网 - HTML5先行者学习网
$.fn.extend({ nvDHTML5中文学习网 - HTML5先行者学习网
Test:function(config){ nvDHTML5中文学习网 - HTML5先行者学习网
/** nvDHTML5中文学习网 - HTML5先行者学习网
* @param effect 效果 nvDHTML5中文学习网 - HTML5先行者学习网
* config||{} 当有自定义属性传进来时不执行默认值 nvDHTML5中文学习网 - HTML5先行者学习网
*/ nvDHTML5中文学习网 - HTML5先行者学习网
// 设置默认值 nvDHTML5中文学习网 - HTML5先行者学习网
config=$.extend({ nvDHTML5中文学习网 - HTML5先行者学习网
effect:'click', nvDHTML5中文学习网 - HTML5先行者学习网
},config||{}); nvDHTML5中文学习网 - HTML5先行者学习网
var effect=config.effect; nvDHTML5中文学习网 - HTML5先行者学习网
var _text=config._text; nvDHTML5中文学习网 - HTML5先行者学习网
if(effect=='click'){ nvDHTML5中文学习网 - HTML5先行者学习网
$(this).click(function(){ nvDHTML5中文学习网 - HTML5先行者学习网
alert('this click'); nvDHTML5中文学习网 - HTML5先行者学习网
}) nvDHTML5中文学习网 - HTML5先行者学习网
}else if(effect=='mouseover'){ nvDHTML5中文学习网 - HTML5先行者学习网
$(this).mouseover(function(){ nvDHTML5中文学习网 - HTML5先行者学习网
alert("this is mouseover"); nvDHTML5中文学习网 - HTML5先行者学习网
}) nvDHTML5中文学习网 - HTML5先行者学习网
} nvDHTML5中文学习网 - HTML5先行者学习网
} nvDHTML5中文学习网 - HTML5先行者学习网
}) nvDHTML5中文学习网 - HTML5先行者学习网
})(jQuery) nvDHTML5中文学习网 - HTML5先行者学习网
nvDHTML5中文学习网 - HTML5先行者学习网 nvDHTML5中文学习网 - HTML5先行者学习网
//调用部分,HTML中的data属性依赖于此 nvDHTML5中文学习网 - HTML5先行者学习网
$(function(){ nvDHTML5中文学习网 - HTML5先行者学习网
var _widget= $("#widget").attr("data-widget-config"); nvDHTML5中文学习网 - HTML5先行者学习网
// 将string转换成json对象的方法,有两种 nvDHTML5中文学习网 - HTML5先行者学习网
var widgetConfigJSON=eval("("+_widget+")"); nvDHTML5中文学习网 - HTML5先行者学习网
// var widgetConfigJSON = (new Function("return " + _widget))(); nvDHTML5中文学习网 - HTML5先行者学习网
$("#widget").Test(widgetConfigJSON); nvDHTML5中文学习网 - HTML5先行者学习网
//因为HTML中data属性是data-widget-config="{effect:'click'}",所以这里会调用点击事件, nvDHTML5中文学习网 - HTML5先行者学习网
如果是data-widget-config="{effect:'mouseover'}",则调用鼠标移上去的事件}) nvDHTML5中文学习网 - HTML5先行者学习网