浅析HTML5:'data-'属性的作用


Posted in HTML / CSS onJanuary 23, 2018

在大家查看HTML时,经常会看到data-role、data-theme等的使用,比如:通过如下代码即可实现页眉的效果:

<div data-role="header">   
     <h1>我是标题</h1>   
</div>

     为什么写一个data-role="header"就能实现底部为黑色、文字居中显示的效果呢?

     本文提供一种最简单的实现办法,让大家对这些用法有个直观的了解。

     我们写一个html页面,自定义一个data-chb="header"的属性,希望具备这个属性的div区域背景颜色为黑色,文字为白色,居中显示;不具备data-chb自定义属性的div按照默认方式显示,html代码如下:

<body>   
  <div data-chb="header">   
    <h1>我是使用了data-chb自定义属性的div</h1>   
  </div>   
  <br/>   
  <div>   
    我没有使用data-chb自定义属性,该怎么展现就怎么展现;   
  </div>   
</body>

要想实现"背景颜色为黑色,文字为白色,居中显示"的显示效果,我们定义如下的css:

<style>   
 .ui_header {   
  background-color: black;   
  text-align: center;   
  color:white;   
  border:1px solid #000;   
}   
</style>

然后我们通过如下js方法实现在页面加载时,动态添加css定义,改变具备data-chb属性的div的显示样式:

<script type="text/javascript">   
    window.onload=function(){   
       var elems = document.getElementsByTagName("div");   
       if(elems!=null&&elems.length>0){   
          var length = elems.length;   
          //遍历所有DIV控件   
          for(var i=0;i<length;i++){   
              var elem = elems[i];   
              //获取该控件的自定义属性   
              var customAttr = elem.dataset.chb;   
             //也可以通过如下方式获得自定义属性   
             //var customAttr = elem.dataset["chb"];   
             //如果是我们预先定义好的header值,表示需要处理   
             if(customAttr=="header"){   
                //添加样式   
                elem.setAttribute("class","ui_header");   
             }   
          }   
      }   
  }   
</script>

当然此属性除了以上作用外,还有其他作用,如通过JS来构造数据,填充数据等;

总结

以上所述是小编给大家介绍的HTML5:'data-'属性的作用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

HTML / CSS 相关文章推荐
使用CSS3代码绘制可爱的Hello Kitty猫
Aug 03 HTML / CSS
纯CSS3实现表单验证效果(非常不错)
Jan 18 HTML / CSS
CSS3 圆角效果
Jul 15 HTML / CSS
css3设置box-pack和box-align让div里面的元素垂直居中
Sep 01 HTML / CSS
js实现移动端H5页面手指滑动刻度尺功能
Nov 16 HTML / CSS
HTML5 Canvas锯齿图代码实例
Apr 10 HTML / CSS
HTML5实现页面切换激活的PageVisibility API使用初探
May 13 HTML / CSS
HTML5 Canvas玩转酷炫大波浪进度图效果实例(附demo)
Dec 14 HTML / CSS
详解html5 postMessage解决跨域通信的问题
Aug 17 HTML / CSS
H5离线存储Manifest原理及使用
Apr 28 HTML / CSS
css背景和边框标签实例详解
May 21 HTML / CSS
CSS子盒子水平和垂直居中的五种方法
Jul 23 HTML / CSS
HTML5 常见面试题之PC端和移动端区别介绍
Jan 22 #HTML / CSS
浅谈html5 video 移动端填坑记
Jan 15 #HTML / CSS
html5 Canvas实现图片旋转的示例
Jan 15 #HTML / CSS
详解html5页面 rem 布局适配方法
Jan 12 #HTML / CSS
详解html5 canvas 微信海报分享(个人爬坑)
Jan 12 #HTML / CSS
利用三角函数在canvas上画虚线的方法
Jan 11 #HTML / CSS
HTML5 Web缓存和运用程序缓存(cookie,session)
Jan 11 #HTML / CSS
You might like
使用swoole扩展php websocket示例
2014/02/13 PHP
php实现mysql数据库操作类分享
2014/02/14 PHP
PHP判断一个数组是另一个数组子集的方法详解
2017/07/31 PHP
加载 Javascript 最佳实践
2011/10/30 Javascript
JavaScript判断访问的来源是手机还是电脑,用的哪种浏览器
2013/12/12 Javascript
使用jquery操作session方法分享
2015/01/22 Javascript
js鼠标单击和双击事件冲突问题的快速解决方法
2016/07/11 Javascript
jQuery简单实现title提示效果示例
2016/08/01 Javascript
jQuery实现的省市联动菜单功能示例【测试可用】
2017/01/13 Javascript
5种JavaScript脚本加载的方式
2017/01/16 Javascript
关于Sequelize连接查询时inlude中model和association的区别详解
2017/02/27 Javascript
详解EasyUi控件中的Datagrid
2017/08/23 Javascript
js实现可以点击收缩或张开的悬浮窗
2017/09/18 Javascript
详解html-webpack-plugin插件(用法总结)
2018/09/12 Javascript
从0到1构建vueSSR项目之node以及vue-cli3的配置
2019/03/07 Javascript
Angular8路由守卫原理和使用方法
2019/08/29 Javascript
微信提示 在浏览器打开 效果实现过程解析
2019/09/10 Javascript
vue-cli3项目配置eslint代码规范的完整步骤
2020/09/10 Javascript
Python fileinput模块使用实例
2015/06/03 Python
Python中实现三目运算的方法
2015/06/21 Python
利用python程序帮大家清理windows垃圾
2017/01/15 Python
python内存动态分配过程详解
2019/07/15 Python
在python中做正态性检验示例
2019/12/09 Python
python Matplotlib模块的使用
2020/09/16 Python
Python根据URL地址下载文件并保存至对应目录的实现
2020/11/15 Python
Old Navy加拿大官网:美式休闲服饰品牌
2017/09/26 全球购物
Antonioli美国在线商店:时尚前卫奢华
2019/07/29 全球购物
衰败城市英国官网:Urban Decay英国
2020/04/29 全球购物
大学生2014全国两会学习心得体会
2014/03/10 职场文书
司法助理专业自荐书
2014/06/13 职场文书
本科生自荐信
2014/06/18 职场文书
六查六看剖析材料
2014/10/06 职场文书
mysql优化
2021/04/06 MySQL
基于Python编写简易版的天天跑酷游戏的示例代码
2022/03/23 Python
配置nginx负载均衡
2022/05/06 Servers
Android studio 简单计算器的编写
2022/05/20 Java/Android