//获取浏览器可视区宽度
function getWidth() {
if (window.innerWidth){
return window.innerWidth;
}
else{
if (document.compatMode == "CSS1Compat"){
return document.documentElement.clientWidth;
}
else{
return document.body.clientWidth;
}
}
}
// 简写
// function getWidth(){
// return window.innerWidth || document.compatMode == "CSS1Compat" ? document.documentElement.clientWidth : document.body.clientWidth;
// } //获取浏览器可视区高度
function getHeight() {
if (window.innerHeight){
return window.innerHeight;
}
else{
if (document.compatMode == "CSS1Compat"){
return document.documentElement.clientHeight;
}
else{
return document.body.clientHeight;
}
}
}
// 简写
// function getHeight(){
// return window.innerHeight || document.compatMode == "CSS1Compat" ? document.documentElement.clientHeight : document.body.clientHeight;
// } //获取浏览器卷曲高度
function getscrollTop() {
if (document.documentElement.scrollTop){
return document.documentElement.scrollTop;
}
else{
return document.body.scrollTop;
}
}
// 简写
// function getscrollTop() {
// return document.documentElement.scrollTop || document.body.scrollTop;
// }
// function getscrollTop() {
// return document.documentElement.scrollTop + document.body.scrollTop;
// } function $(id){
return document.getElementById(id);
} // 由于getElementsByClassName()方法有兼容性问题 (IE8以下不兼容)
// 所以利用getElementsByTagName()方法封装一个函数模拟ByClassName函数功能
// 参数: class类名
// 返回值:匹配到的所有元素节点
function getClassName(cName){
var all = document.getElementsByTagName("*");
var arrays = new Array();
for(var i = 0; i < all.length; i++){
if (all[i].className == cName){
arrays.push(all[i])
}
}
return arrays;
} // 获取元素非行间样式的值
// 参数1:元素节点
// 参数2:属性名
function getStyle(element, attrName){
if (element.currentStyle) {
return element.currentStyle[attrName];
}
else{
return window.getComputedStyle(element, null)[attrName];
}
} // 返回元素的子节点(过滤掉空白文本 以及 注释节点后的)
// 参数:元素节点
// 返回值: 元素节点的子集节点
function getChildNodes(element){
var eList = element.childNodes;
var arrays = new Array();
for (var i = 0; i < eList.length; i++) {
if (eList[i].nodeType == 1) { //元素节点:1 属性节点:2 文本节点:3 注释节点:8
arrays.push(eList[i])
}
}
return arrays;
} // 返回元素的第一个子节点 (过滤掉空白文本 以及 注释节点后的)
// 参数:元素节点
// 返回值: 元素节点的第一个子元素节点
function getFirstChild(element){
var eList = element.childNodes;
var firstChild = null;
for (var i = 0; i < eList.length; i++) {
if (eList[i].nodeType == 1) {
firstChild = eList[i];
break;
}
}
return firstChild;
} // 返回元素的最后一个子节点 (过滤掉空白文本 以及 注释节点后的)
// 参数:元素节点
// 返回值: 元素节点的最后一个子元素节点
function getLastChild(element){
var eList = element.childNodes;
var lastChild = null;
for (var i = eList.length - 1; i >= 0; i--) {
if (eList[i].nodeType == 1) {
lastChild = eList[i];
break;
}
}
return lastChild;
} // 返回元素的上一个同级节点
// 参数: 元素节点
// 返回值: 元素的上一个同级节点
function getPreviousSibling(element){
var obj = element.previousSibling;
while (obj != null && obj.nodeType != 1){ //循环会在指定条件为真时循环执行代码块。
obj = obj.previousSibling;
}
return obj;
} // 返回元素的下一个同级节点
// 参数: 元素节点
// 返回值: 元素的下一个同级节点
function getNextSibling(element){
var obj = element.nextSibling;
while (obj != null && obj.nodeType != 1){ //循环会在指定条件为真时循环执行代码块。
obj = obj.nextSibling;
}
return obj;
} // 原理:由于e.pageY和pageX这个属性在IE低版本中不支持(8及以下),所以利用可视区鼠标的位置加上滚动条卷曲高度来获取基于内容区的鼠标的位置
// 作用:获取鼠标相对内容区的鼠标Y轴位置
// 参数:相对可视区的鼠标位置 (e.pageY)
// 返回值:相对内容区的鼠标位置
function getPageY(y){
return y + document.documentElement.scrollTop + document.body.scrollTop;
} // 封装dom 2级事件,添加卸载的函数
// 参数:
// 1:操作的元素
// 2:事件类型 (去掉on后)
// 3:执行的非匿名函数
// 4:捕获/冒泡(true/false)
// 添加事件
function addEvent(element, type, fn, method){
if (element.addEventListener){
element.addEventListener(type, fn, method)
}
else{ //IE浏览器 8 级以下
element.attachEvent("on" + type, fn);
}
}
// 卸载事件
function delEvent(element, type, fn, method){
if (removeEventListener) {
element.removeEventListener(type, fn, method);
}
else{
element.detachEvent("on" + type, fn)
}
} // e.target 获取拥有该事件对象的本身,等同于this 非IE浏览器使用
// e.srcElement 获取拥有该事件对象的本身,等同于this IE浏览器使用
// e.type 获取该事件类型 // 作用: 阻止事件默认行为
// 参数:事件源对象
function myPreventDefault(eobj){
if (eobj.preventDefault){
eobj.preventDefault(); //IE8以上,及火狐谷歌等
}
else{
eobj.returnValue = false; //ie8及以下
}
} // 作用: 阻止事件冒泡
// 参数: 事件源对象
function myStopPropagation(eobj) {
if (eobj.stopPropagation){
eobj.stopPropagation(); //非IE 下阻止事件冒泡的方法
}
else{
eobj.cancleBubble = true; //IE8及以下浏览器阻止事件冒泡
}
} // 作用: 判断鼠标左右键
function getMouseDirection(e){
e = e || event;
//e.button === 0 IE高版本(9以上)火狐谷歌
//e.button === 1 IE低版本 8及以下
if (e.button === 0 || e.button === 1){
return "左键";
}
if(e.button === 2){
return "右键";
}
} // 封装cookie
// 设置cookie
// 参数: 1:键名 2:键值 3.过期时间(可传可不传)
function setCookie(key, value, dateTime){
var cValue = key + "=" + encodeURIComponent(value); //编码(防止中文)
if (dateTime){
cValue += ";expires=" + dateTime;
}
document.cookie = cValue;
}
// 获取cookie
function getCookie(key){
var arr = document.cookie.split("; ");
var keyValue = "";
for (var i = 0; i < arr.length; i++){
var keyName = arr[i].split("=")[0];
if (keyName === key){
keyValue = arr[i].split("=")[1];
break;
}
}
return decodeURIComponent(keyValue); //解码 (防治中文)
}
//删除cookie
function delCookie(key){
document.cookie = key+"=expires=" + new Date(0);
}

未完,待续...

JS 兼容大全的更多相关文章

  1. JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记2

    技术很多,例子很多,只好慢慢学,慢慢实践!!现在学的这本书是[JavaScript实战----JavaScript.jQuery.HTML5.Node.js实例大全] JavaScript.jQuer ...

  2. js 事件大全

    Js事件大全一般事件 事件 浏览器支持 描述onClick IE3|N2|O3 鼠标点击事件,多用在某个对象控制的范围内的鼠标点击onDblClick IE4|N4|O 鼠标双击事件onMouseDo ...

  3. JS正则表达式大全

    转自:http://wenku.baidu.com/link?url=3y930kC7F6D3wQdMjQ3fVDmiA9Wfebs_QK0UB3N3mFaEoKg4ytZORPopxufeYA6si ...

  4. 实用js代码大全

    实用js代码大全 //过滤数字 <input type=text onkeypress="return event.keyCode>=48&&event.keyC ...

  5. io.js - 兼容 NPM 平台的 Node.js 新分支

    io.js(JavaScript I/O)是兼容 NPM 平台的 Node.js 新分支,由 Node.js 的核心开发者在 Node.js 的基础上,引入更多的 ES6 特性,它的目的是提供更快的和 ...

  6. JS正则表达式大全(整理详细且实用)

    JS正则表达式大全(整理详细且实用).需要的朋友可以过来参考下,希望对大家有所帮助!! 正则表达式中的特殊字符 字符 含意 \ 做为转意,即通常在"\"后面的字符不按原来意义解释, ...

  7. js代码大全

    超级实用且不花哨的js代码大全 事件源对象event.srcElement.tagNameevent.srcElement.type 捕获释放event.srcElement.setCapture() ...

  8. JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记3

    技术很多,例子很多,只好慢慢学,慢慢实践!!现在学的这本书是[JavaScript实战----JavaScript.jQuery.HTML5.Node.js实例大全] JavaScript.jQuer ...

  9. JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记1

    技术很多,例子很多,只好慢慢学,慢慢实践!!现在学的这本书是[JavaScript实战----JavaScript.jQuery.HTML5.Node.js实例大全] 第 3 章 用 JavaScri ...

随机推荐

  1. 对io进行分流

    package org.richin.io.Stream.util;     import java.io.BufferedInputStream;     import java.io.Buffer ...

  2. HTML5 number类型文本框step属性的验证机制——张鑫旭

    我在下一盘很大的棋,本文只是其中的一个棋子. 需要提前知道的: 目前而言,对step雄起的浏览器为IE10+, Chrome以及Opera浏览器. 需要预先知道number类型input的一些基本知识 ...

  3. Spring 中使用XML配置方式和使用注解方式实现DI

    Spring容器给我们提供了很好的环境,我们只关注主要业务即可,其他的无需关注太多.今天刚学的DI DI(Dependency Injection):依赖注入 使用XML配置文件完成依赖注入 1.1普 ...

  4. 宝塔面板nginx配置安装Discuz

    Discuz!在Nginx下的Rewrite 需要说明的是,下网上以前一直流传的Rewrite都是有误的. 下面的Rewrite中百分号前面多了个转移字符"",这在Apache中是 ...

  5. DOM增删操作(创建删除表格)

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...

  6. 用CSS的方法如何让一个元素不可见?(面试题目)

    面试中看到这个问题,自己想的不全面,下面整理下,一起学习: 一.CSS元素隐藏 在CSS中,让元素隐藏(指屏幕范围内肉眼不可见)的方法很多,有的占据空间,有的不占据空间:有的可以响应点击,有的不能响应 ...

  7. 语义化的HTML及其目的

    一.什么是语义化的HTML? 语义化的HTML就是写出的HTML代码,符合内容的结构化(内容语义化),选择合适的标签(代码语义化),能够便于开发者阅读和写出更优雅的代码的同时让浏览器的爬虫和机器很好地 ...

  8. 网络I/O模型--02阻塞模式(多线程)

    当服务器收到客户端 X 的请求后(读取到所有请求数据后),将这个请求送入一个独立线程进行处理,然后主线程继续接收客户端 Y 的请求. 客户端一侧也可以使用一个子线程和服务器端进行通信.这样客户端主线程 ...

  9. FineReport中树数据集如何实现组织树报表

    组织树报表中由id与父id来实现组织树报表,若层级数较多时,对每个单元格设置过滤条件和形态会比较繁琐,因此FineReport提供了一种特殊的数据集——树数据集,只需要简单的设置就能自动递归出层级,方 ...

  10. linux 命令及配置文件搜索命令which、whereis

    which /usr/bin/which 搜索命令所在目录及别名信息 which lsalias ls='ls --color=auto'/usr/bin/ls which rmalias rm='r ...