DOM系统学习-表格、样式和元素大小
操作表格
属性:
caption 标题元素
tHead 表头元素
tFoot 表尾元素
tBodies 主体元素集合,通过下标取
row 行元素集合,通过下标取
方法:
createCaption()
createTHead()
createTFoot()
deleteCaption()
deleteTHead()
deleteTFoot()
deleteRow(pos)
insertRow(pos)
tbody的属性和方法:
rows 行集合
deleteRow(pos) 删除第几行
insertRow(pos) 插入行到那个位置
tr的属性和方法:
cells 单元格集合
deleteCell(pos) 删除单元格
insertCell(pos) 插入单元格到那个位置
注意:
不支持td,tbody方法
操作样式
检查dom2级css能力:
|
1
|
document.implementation.hasFeature('CSS2','2.0'); |
访问元素的样式:
行内样式:
调用方式
style.color,style.fontSize,style[font-size]
属性
cssText css文本内容
length 样式个数
方法
getPropertyPriority(name) 含有important则返回important
getPropertyValue(name) 获取属性值
setProperty(name,v,p) 设置属性
removeProperty(name) 移除属性
获取计算后的样式:
IE不支持getComputedStyle
IE支持currentStyle属性
|
1
|
var style = window.getComputedStyle ? window.getComputedStyle(table,null) : null || table.currentStyle; |
操作样式表:
基本方式
ele.id
ele.className
三个定义方法
是否存在class
|
1
2
3
4
|
//判断是否存在这个classfunction hasClass(element, className) { return element.className.match(new RegExp('(\\s|^)' + className + '(\\s|$)'));} |
添加class
|
1
2
3
4
5
6
|
//添加一个class,如果不存在的话 function addClass(element, className) { if (!hasClass(element, className)) { element.className += " " + className; }} |
删除class
|
1
2
3
4
5
6
|
//删除一个class,如果存在的话 function removeClass(element, className) { if (hasClass(element, className)) { element.className = element.className.replace(new RegExp('(\\s|^)' + className + '(\\s|$)'), ' '); }} |
HTMLLinkElement,HTMLStyleElement
|
1
|
var link = document.getElementsByTagName('link')[0]; |
sheet属性兼容
非IE使用sheet
IE使用styleSheet
|
1
|
var sheet = link.sheet || link.styleSheet; |
css规则
非IE sheet.clssRules、sheet.deleteRule()、sheet.insertRule()
IE sheet.rules、sheet.removeRule()、sheet.addRule()
|
1
2
3
4
5
6
7
8
9
|
function insertRule(sheet, selectorText, cssText, position) { //如果是非IE if (sheet.insertRule) { sheet.insertRule(selectorText + "{" + cssText + "}", position); //如果是IE } else if (sheet.addRule) { sheet.addRule(selectorText, cssText, position); }} |
|
1
2
3
4
5
6
7
8
9
|
function deleteRule(sheet, index) { //如果是非IE if (sheet.deleteRule) { sheet.deleteRule(index); //如果是IE } else if (sheet.removeRule) { sheet.removeRule(index); }} |
获取元素
CSS大小:
通过style内联获取元素大小
ele.style.width、 ele.style.height
通过计算元素大小
|
1
|
var style = window.getComputedStyle ? window.getComputedStyle(table,null) : null || table.currentStyle; |
sytle.width、style.height
通过CSSStyleSheet
|
1
2
|
var sheet = document.styleSheets[0]; //获取link 或stylevar rule = (sheet.cssRules || sheet.rules)[0]; //获取第一条规则 |
rule.style.width、rule.style.height
实际大小:
元素可视区大小 内容+内边距
ele.clientWidth、ele.clientHeight
元素滚动内容大小 滚动条
ele.scrollWidth、ele.scrollHeight
元素实际大小 内容+内边距+边框+滚动条
ele.offsetWidth、ele.offsetHeight
周边大小:
边框大小 不支持右下
ele.clientLeft、ele.clientTop
相对父元素的位置
ele.offsetLeft、ele.offsetTop
滚动条被隐藏的大小
ele.scrollLeft、ele.scrollTop
DOM系统学习-表格、样式和元素大小的更多相关文章
- DOM系统学习-进阶
DOM类型 Node类型: 常用类型: 元素节点 ELEMENT_NODE 属性节点 ATTRIBUTE_NODE 文本节点 TEX ...
- DOM系统学习-基础
DOM介绍 DOM介绍: D 网页文档 O 对象,可以调用属性和方法 M 网页文档的树型结构 节点: DOM将树型结构理解为由节点组成. 节点种类: 元素节点.文本节点.属性节点等 查找元 ...
- Javascript高级编程学习笔记(52)—— DOM2和DOM3(4)元素大小
在日常实践中,我们在使用JS的时候难免会需要获取元素的大小及位置 首先要声明的是,这一部分的内容并不属于DOM2样式规范,因为DOM中并没有对我们如何获取元素大小的相关信息做出规范 偏移量 偏移量及元 ...
- 【学习笔记】HTML基础:列表、表格与媒体元素
一.列表是信息资源的一种展现形式,它可以使信息结构化和条理化,并以列表的样式显示出来,以便浏览者能够快速的获取相应的信息. 1.无需列表 <ul> <li>第一项</li ...
- 剑指前端(前端入门笔记系列)——DOM(元素大小)
DOM——元素大小 DOM中没有规定如何确定页面中与元素的大小,IE率先映入了一些属性来确定页面中元素的大小,以便开发人员使用,目前,所有主要的浏览器都已经支持这些属性了. 1.偏移量(单位为 ...
- android学习笔记50——SQLiteOpenHelper、android实现系统自带样式
SQLiteOpenHelper SQLiteOpenHelper是android提供的一个管理数据库的工具类,可用于管理数据库的创建和版本更新. 一般的用法是创建SQLiteOpenHelper的子 ...
- DIV+CSS系统学习:转载
第一部分 HTML 第一章 职业规划和前景 职业方向规划定位: web前端开发工程师 web网站架构师 自己创业 转岗管理或其他 web前端开发的前景展望: 未来IT行业企业需求最多的人才 结合最新的 ...
- dojo/dom-geometry元素大小
在进入源码分析前,我们先来点基础知识.下面这张图画的是元素的盒式模型,这个没有兼容性问题,有问题的是元素的宽高怎么算.以宽度为例,ff中 元素宽度=content宽度,而在ie中 元素宽度=conte ...
- HTML+CSS纯干货就业前基础到精通系统学习2016/9/3
1:HTML纯干货学习后的达到的效果 (1):会使用HTML的基本结构,创建网页 (2):会使用文本字体相关标签,实现文字修饰和布局 (3):会使用图像.超链接相关标签,实现图文并茂的页面 (4):会 ...
随机推荐
- [BZOJ1004] [HNOI2008]Cards解题报告(Burnside引理)
Description 小春现在很清闲,面对书桌上的N张牌,他决定给每张染色,目前小春只有3种颜色:红色,蓝色,绿色.他询问Sun有多少种染色方案,Sun很快就给出了答案.进一步,小春要求染出Sr张红 ...
- 服务器应用程序不可用,由于无法创建应用程序域,因此未能执行请求。错误: 0x80070002 系统找不到指定的文件。
使用360更新网站补丁导致.net2.0环境报错问题现象:服务器应用程序不可用查看日志:出现由于无法创建应用程序域,因此未能执行请求.错误: 0x80070002 系统找不到指定的文件. 搜索定位:罪 ...
- bzoj 1861 splay
就是裸地splay,然后自己写的不是特别好,tle了,最近时间比较紧迫,有时间了改下,在此记录 另附转载pascal AC代码最下面 /******************************** ...
- python3 匿名函数,map/reduce/filter等函数结合应用
匿名函数就是不需要显式的指定函数 # 平方函数 def func1(x): return x**2 print(func1) # 平方函数匿名函数写法 func2=lambda x:x**2 prin ...
- 常见协议基础知识总结--DHCP协议
DHCP动态主机配置协议,简单点说,就是提供了自动获取ip地址的功能,基于四层的UDP协议: 以下描述此协议的整个工作流程: (1) 客户端发送discovery报文,二三层广播报文,源ip地址全0: ...
- Linux makefile 教程 非常详细,且易懂【转】
转自: http://blog.csdn.net/liang13664759/article/details/1771246 最近在学习Linux下的C编程,买了一本叫<Linux环境下的C ...
- 解析gtest框架运行机制
前言 Google test是一款开源的白盒单元测试框架,据说目前在Google内部已在几千个项目中应用了基于该框架的白盒测试. 最近的工作是在搞一个基于gtest框架搭建的自动化白盒测试项目,该项目 ...
- java使用maven项目(二)分模块开发
1 整合ssh框架 1.1 依赖传递 只添加了一个struts2-core依赖,发现项目中出现了很多jar, 这种情况 叫 依赖传递 1.2 依赖版本冲突的解决 1. 第 ...
- js 集合
[深入理解javascript原型和闭包系列 ] 历时半月完稿,求推荐 jQuery 学习笔记(未完待续) JavaScript作用域原理(三)——作用域根据函数划分
- ros中删除某个包之后用apt安装的包找不到
原因是工作空间devel里还存有原来的二进制可执行文件,将build和devel内容全删除后再catkin_make就好了