据说每个大牛、小牛都应该有自己的库——DOM处理
这几天整理了一下思路,本来觉得DOM部分会有很多东西,但是忽然发现频繁使用的其实并不太多
class
class处理部分主要有四个
hasClass:检查元素是否包含某个class
addClass:为元素添加一个class
removeClass:为元素删除一个class
toggleClass:切换元素的class, 如果只传入一个class,则切换这个class的有无;如果传入两个class,则元素删除当前class,替换为另一个
hasClass : function(element, className) {
var re = new RegExp("(^|\\s)" + className + "(\\s|$)", "i");
if (element.className.match(re))
return true;
return false;
},
addClass : function(element, className) {
var re = new RegExp("(^|\\s)" + className + "(\\s|$)", "gi");
var eleClass = element.className;
if (!eleClass.match(re))
element.className = eleClass + " " + className;
},
removeClass : function(element, className) {
var re = new RegExp("(^|\\s)" + className + "(\\s|$)", "gi");
var eleClass = element.className;
eleClass = eleClass.replace(re, "");
if (element.className != eleClass)
element.className = eleClass;
},
toggleClass:function(element,class1,class2){
if(class2!=undefined){
if(ssLib.hasClass(element,class1)){
ssLib.removeClass(element,class1);
ssLib.addClass(element,class2);
}else if(ssLib.hasClass(element,class2)){
ssLib.removeClass(element,class2);
ssLib.addClass(element,class1);
}
}else{
if(ssLib.hasClass(element,class1)){
ssLib.removeClass(element,class1);
}else{
ssLib.addClass(element,class1);
}
}
},
元素尺寸
元素尺寸有两个方法
getRect:获取元素尺寸,同时包含其上下左右四个边的位置
getViewPortSize:获取可视窗口(ViewPort,不含滚动条)尺寸
getScrollSize:获取元素(包含滚动条)尺寸
getRect : function(element) {
var rect = element.getBoundingClientRect();
if (typeof rect.width == 'undefined') {
_rect = {
width : rect.right - rect.left,
height : rect.bottom - rect.top,
top : rect.top,
bottom : rect.bottom,
left : rect.left,
right : rect.right
};
return _rect;
}
return rect;
},
getViewPortSize : function() {
if (document.compatMode == "CSS1Compat") {
return {
width : document.documentElement.clientWidth,
height : document.documentElement.clientHeight
};
} else {
return {
width : document.body.clientWidth,
height : document.body.clientHeight
};
}
},
getScrollSize : function(element) {
var e = element
|| (document.compatMode == "CSS1Compat" ?
document.documentElement: document.body);
return {
width : Math.max(element.scrollWidth, element.clientWidth),
height : Math.max(element.scrollHeight, element.clientHeight)
};
},
元素位置
getScrollPos:获取元素滚动条位置
getViewPortPos:获取元素相对于可视窗口(ViewPort,不包括滚动条)的位置
getAbsolutePos:获取元素相对于文档(包含滚动条)位置
getOffsetPos:获取文档相对于父容器位置
getScrollPos : function(element) {
var e = element
|| (document.compatMode == "CSS1Compat" ? document.documentElement
: document.body);
return {
x : e.scrollTop,
y : e.scrollLeft
};
},
getViewPortPos : function(element) {
var rect = element.getBoundingClientRect();
return {
x : rect.left,
y : rect.top
};
},
getAbsolutePos : function(element) {
var rect=element.getBoundingClientRect();
var doc = document.compatMode == "CSS1Compat" ? document.documentElement
: document.body;
return{
x:rect.left+Math.max(doc.scrollLet,doc.clientLeft),
y:rect.top+Math.max(doc.scrollTop,doc.clientTop)
};
},
getOffsetPos:function(element){
return{
x:element.offsetLeft,
y:elementoffsetTop
};
}
元素属性/样式
这个借鉴了一下jQuery的写法
attr:获取/设置元素的属性值
css:获取/设置元素的style
这两个函数是临时想到的,还没想好怎么写,明天晚上补上吧
PS.最近公司太忙,拖了这么久终于补上了,由于内容不少,另外写了一篇据说每个大牛、小牛都应该有自己的库——DOM处理续,另外由于这次写的仓促,除了很多漏洞,谢谢大家不吝指教,感觉进步了很多
据说每个大牛、小牛都应该有自己的库——DOM处理的更多相关文章
- 据说每个大牛、小牛都应该有自己的库——DOM处理续
在上篇据说每个大牛.小牛都应该有自己的库——DOM处理最后剩下attr()和css()方法没有处理,因为这两个方法当时并不自计划中,是写着写着突然想到的,一时间没有特别好的思路,当时已十一点多了,就去 ...
- 据说每个大牛、小牛都应该有自己的库——JavaScript原生对象拓展
在据说每个大牛.小牛都应该有自己的库——框架篇中我扬言要做个小牛,没想到一天没更新,小伙儿伴们就戏谑的问我,油哥是不是要太监了?其实事情是这个样子的,这不是太监的节奏,一是,关于写个自己的库的想法由来 ...
- 据说每个大牛、小牛都应该有自己的库——Event处理
今天抽时间写了一部分Event处理方面的函数愈发的觉得jQuery的优秀,自己前期的想法太粗糙,造成后面这些函数参数很多,操作很很不直观,看样子是要重构的节奏,还好小伙儿伴们安慰,架构都是改出来的.继 ...
- 据说每个大牛、小牛都应该有自己的库——Ajax
蹉跎到今天终于要写Ajax部分了,平时工作中除了选择器我用jQuery的最多的就是ajax,所以这部分在自己的框架中必不可少. XMLHttpRequest 我以为对每个使用过Ajax的人来说XMLH ...
- 让所有网站都提供API的Python库:Toapi
这是一个让所有网站都提供API的Python库.以前,我们爬取数据,然后把数据存起来,再创造一个api服务以便其他人可以访问.为此,我们还要定期更新我们的数据.这个库让这一切变得容易起来.你要做的就是 ...
- Xcode 5.1 编译模拟器以及真机都能使用的静态库
Xcode 5.1.dmg 下载地址 http://pan.baidu.com/s/1jGJpKm6 1.新建 Framework & Library 工程 我起名叫ShowInfo,下面为其 ...
- pycharm每次新建项目都要重新安装一些第三方库的解决办法(转载防删)
目前有三个解决办法,也是亲测有用的: 第一个方法:因为之前有通过pycharm的project interpreter里的+号添加过一些库,但添加的库只是指定的项目用的,如果想要用,就必须用之前的项目 ...
- 每个android项目都应该使用的android 库
http://blog.teamtreehouse.com/android-libraries-use-every-project A good developer knows to never re ...
- JavaScript原生对象拓展
JavaScript原生对象拓展 在据说每个大牛.小牛都应该有自己的库——框架篇中我扬言要做个小牛,没想到一天没更新,小伙儿伴们就戏谑的问我,油哥是不是要太监了?其实事情是这个样子的,这不是太监的节奏 ...
随机推荐
- STL 跨模块 调用 异常 解决
本文为转载别人的,以作收藏之用 百度了一天,现在把结论放上边: 1.不要用STL(std::string属于STL)来跨模块传输数据,例如:dll(so)之间,dll(so)和exe(elf)之间. ...
- virtual 修饰符 C# .NET
virtual 关键字用于修饰方法.属性.索引器或事件声明,并且允许在派生类中重写这些对象. 例如,此方法可被任何继承它的类重写. (C#参考) public virtual double Area( ...
- 浅论ViewController的加载 -- 解决 viewDidLoad 被提前加载的问题(pushViewController 前执行)
一个ViewController,一般通过init或initWithNibName来加载.二者没有什么不同,init最终还是要调用initWithNibName方法(除非这个ViewControlle ...
- lua 位运算
bit = {data32={}} , do bit.data32[i] = ^(-i) end function bit:d2b( arg ) local num = tonumber( arg ) ...
- 解决Ubuntu下Chrome浏览器网页中文字体混乱
在Ubuntu下使用Chrome浏览器时碰到了网页中文字体混乱的现象: 黑体和楷体混杂,看起来非常不美观. 这是由于许多网页并没有指定字体,然后浏览器将调用系统默认字体配置. 首先,安装文泉驿字体: ...
- 【细说Java】关于main方法的一些细节
Public static void main(String[] args) public :main方法是jvm运行的入口,所以必须是public来供外部调用 static :main方法无需生成对 ...
- VIM使用(一) VIM插件管理利器-vundle
有关VIM的文件网上一大堆,这里只是记录一下我新配置环境的步骤.以备查看参考. sudo apt-get install gitgit clone https://github.com/gmarik/ ...
- Linux终端杀手、程序员利器-Tmux
Send article as PDF SA.Coder.经常远程.还在开一堆终端?试试 Tmux 吧,一个窗口就搞定. 目录 0.0.0.1 Tmux ? Tmux 是一个终端复用 ...
- android 连接蓝牙扫码枪,程序崩溃之onConfigurationChanged
当android手机通过蓝牙连接扫码枪时,程序崩溃的原因之一是:键盘弹出或隐藏,触发程序走了onDestory->onCreate的生命周期,从而可能使得页面的某些初始化数据被清除了. 解决方法 ...
- java——多线程——内部类共享同一个外部类对象的成员变量
public class Shop { public static void main(String[] args) { Outer o=new Outer(); Thread t1=o.getSal ...