js,mui,jq 操作基本的DOM
一。HTML
<ul>
<li>1111111</li>
<li>22222222</li>
</ul>
二。CSS
li{
height: 60px;
line-height: 60px;
text-align: center;
font-size: 14px;
color: red;
padding: 4px;
border: 1px solid black;
}
1.获取宽高:
jq:$("div").height();
js:document.getElementsByTagName("ul")[0].getElementsByTagName("li")[0].offsetHeight;
mui:获取第一个li高度就是mui("ul li")[0].offsetHeight;第二个li就是mui("ul li")[1].offsetHeight;
备注:来看看height,scrollHeight,offsetHeight,clientHeight这几个的区别与联系:
clientHeight:理解为内容可视区域的高度,不包含border,不包含border,不包含border;padding是算在里面的。就是clientHeight=height(设置的高度) + padding - 横向滚动条的高度;
offsetHeight:offsetHeight = clientHeight + border + 横向滚动条(横向,横向,就是overflow-x:scroll出现的那个滚动条的高度,默认应该都是17px);
scrollHeight: 经过测试,我得出:scrollHeight=clientHeight+滚动条滚动的距离(高度就是竖直滚动条滚动的距离,宽度就是横向滚动条滚动的距离);
注意了,注意了:在mui里面,在mui里面,在mui里面,clientHeight,offsetHeight的滚动条是不算高度的,也就是offsetHeight = clientHeight + border。clientHeight=height-border;辣么在mui里面上面的li:offsetHeight=height,clientHeight就是58px;
总结:1.pc端:clientHeight=height(设置的高度) + padding - 横向滚动条的高度,如果没有滚动条就不减;offsetHeight = clientHeight + border + 横向滚动条,如果没有滚动条就不加;
2.移动端:2.1 有mui.css:offsetHeight = clientHeight + border。clientHeight=height-border;滚动条不算宽高。 (火狐浏览器里调试一定要设置成响应式设计模式哦,不然得出的高度会让你怀疑人生的)
2.2 无mui.css,只有<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />;
有无滚动条都是:clientHeight=height(设置的高度) + padding;offsetHeight=clientHeight+border;
其它浏览器版本没测试过,不知道是否是一样的。
高度明白了,宽度就是一样的道理。。。
还有:js操作dom元素什么时候加[0]。document.getElementById("")这种,因为id在页面中是唯一的一个所以,通过id来寻找的是不用加[0]的,但是document.getElementsByTagName或者document.getElementsByClassName("")这种,页面上可能含有多个,是个数组,所以需要用[ 0 ],相当于索引一样来获取。mui类似。
jQuery有时候也会有加[0]的时候,比如$("div")[0].innerHtml = "111",是因为innerHtml是一个DOM对象的属性,需要把jQuery对象转换成DOM对象才能使用innerHtml属性,不然会报错。其实jQuery也有自己的innerHtml方法,就是$("div").html(“111”);
2.添加和删除Class属性(mui的添加和删除感觉和原生的一样)
jq: 添加:$("ul li:nth-child(1) p").addClass("active");
删除:$("ul li").eq(0).find("p").removeClass("active");
js: 添加:document.getElementsByTagName("ul")[0].getElementsByTagName("li")[0].classList.add("active")
删除:document.getElementsByTagName("ul")[0].getElementsByTagName("li")[0].classList.remove("active")
mui: 添加:mui("ul li")[1].classList.add("active")
删除:mui("ul li")[1].classList.remove("active")
3.CSS属性的设置和获取:
jq:设置:$("ul li").css("background","red");
获取:$("ul li").css("background");
js: 设置:js设置css样式有以下几种方式:element是获取到的DOM对象
1.element.style.width="100px" //style对象下面的属性介绍http://www.w3school.com.cn/jsref/dom_obj_style.asp
2.element.style.cssText="width:100px;height:100px";//一次可以设置多个属性
3.element.setAttribute('style', 'height: 100px');
4.element.style.setProperty("background","red");
获取:1.element.style.backgroundColor //只能获取内联样式 ,但是backgroundColor非内联也可获取。注:如果是background-color这种,需要写成驼峰样式即backgroundColor。
2.element.currentStyle.height //IE浏览器获取非内嵌样式
3.在非IE浏览器:window.getComputedStyle(element,null/伪类).height;如果是element本身,那么第二个参数就是null,如果需要伪类的样式,则第二个参数为伪类。document.defaultView.getComputedStyle(element,null/伪类)一样的。
备注:做兼容:var a=element.currentStyle ? element.currentStyle : window.getComputedStyle(element, null)。看是否支持currentStyle,也就是看是否处在ie浏览器下。
mui:
其它的请看我的这篇详细文章
js,mui,jq 操作基本的DOM的更多相关文章
- js和jq文档操作
JS文档操作 一.dom树结构 1.元素节点 2.文本节点 3.属性节点 不属于元素节点的子节点 4.文档节点(document) 二.处理元素节点 method 1.docu ...
- jq选择器(jq 与 js 互相转换),jq操作css样式 / 文本内容, jq操作类名,jq操作全局属性,jq获取盒子信息,jq获取位置信息
jq选择器(jq 与 js 互相转换) // 获取所有的页面元素jq对象 $('css3选择器语法'); var $box = $(".box:nth-child(1)"); 获取 ...
- JS中Float类型加减乘除 修复 JQ 操作 radio、checkbox 、select LINQ to SQL:Where、Select/Distinct LINQ to SQL Count/Sum/Min/Max/Avg Join
JS中Float类型加减乘除 修复 MXS&Vincene ─╄OvЁ &0000027─╄OvЁ MXS&Vincene MXS&Vincene ─╄Ov ...
- jq与js获取值操作
jq与js获取值操作 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> &l ...
- mui webview操作
HBuilder的webview操作 webviewAPI文档:http://www.html5plus.org/doc/zh_cn/webview.html 创建新的webview窗口: Webvi ...
- JS与JQ的对比与提高
来吧, 案例1:先上个例子js写的省市二级联动 <!DOCTYPE html><html> <head> <meta charset="UTF-8& ...
- JS、JQ相关小技巧积攒
JS.JQ相关小技巧积攒,以备不时之需. 1.js 获取时间差:时间戳相减.new Date().getTime() 获得毫秒数,除以(1000*60*60*24) 获得天数. 2.重定向操作:页面 ...
- 【转】从Vue.js源码看异步更新DOM策略及nextTick
在使用vue.js的时候,有时候因为一些特定的业务场景,不得不去操作DOM,比如这样: <template> <div> <div ref="test" ...
- html select控件的jq操作
html select控件的jq操作 1.判断select选项中 是否存在Value="paraValue"的Item $("#selectid option[@valu ...
随机推荐
- Rop框架学习笔记
1. 提供了开发服务平台的解决方案:比如应用认证.会话管理.安全控制.错误模型.版本管理.超时限制 2. 启动:RopServlet截获http请求 配置: <servlet> < ...
- mysql数据库忘记密码时如何修改
工具/原料 mysql数据库 cmd命令行 打开mysql.exe和mysqld.exe所在的文件夹,复制路径地址 打开cmd命令提示符,进入上一步mysql.exe所在的文件夹
- jmeter(psot) 表单提交 注意项
Form表单提交:直接使用表单方式提交即可,此方式采取页面直接跳转的形式.用jmeter请求的时候,日志打印传的参数是空的.考虑到form提交和http的提交请求头可能是不一样的,所以优化了请求头: ...
- PRML读书笔记_绪论曲线拟合部分
一.最小化误差函数拟合 正则化( regularization )技术涉及到给误差函数增加一个惩罚项,使得系数不会达到很大的值.这种惩罚项最简单的形式采用所有系数的平方和的形式.这推导出了误差函数的修 ...
- MyBatis是如何解决Sql注入的
转:[转]mybatis如何防止sql注入 java中预处理PrepareStatement为什么能起到防止SQL注入的作用??!! 一.SQL注入 sql注入大家都不陌生,是一种常见的攻击方式,攻击 ...
- MongoDb在windows10下的安装、创建用户和数据库
1.mongodb下载地址https://www.mongodb.com/download-center#community 2.安装 3.在D:\MongoDB目录下创建db和log两个文件夹 ...
- rem布局进阶
<script>!function(e){function t(a){if(i[a])return i[a].exports;var n=i[a]={exports:{},id:a,loa ...
- Delphi2007精简版加载Borland.Studio.Together.dll错误解决办法
安装Delphi2007精简版,启动提示Borland.Studio.Together.dll加载错误,错误信息如下: Failed to load IDE add in 'C:\Program Fi ...
- linux-shell系列8 netstat用法
1 查看TCP连接状态 netstat -n|awk '{print $6}'|sort|uniq -c|sort -rn netstat -n|awk '/^tcp/ {++S[$NF]};END{ ...
- BZOJ1419Red is good——概率DP
题目描述 桌面上有R张红牌和B张黑牌,随机打乱顺序后放在桌面上,开始一张一张地翻牌,翻到红牌得到1美元,黑牌则付 出1美元.可以随时停止翻牌,在最优策略下平均能得到多少钱. 输入 一行输入两个数R,B ...