简单的可兼容所有浏览器的操作html元素的javascript框架
1.根据id名称取元素 $id(idName)
2.根据class定义取元素 $class(className)返回所有class被定义成className的元素数组,或者$Eclass(className)返回第一个元素
3.根据tag名称取元素 $tag(tagName)返回所有标签名称为tagName的元素数组,或者$Etag(tagName)返回第一个元素
4.父子关系下取元素 $dom(id#idName class#className tag#tagName)返回idName元素下的所有class为className的所有元素的标签名称为tagName的元素数组,或者$Edom(id#idName class#className tag#tagName)返回第一个元素,每个关系之间以空格分隔,对应关系以井号分隔,关系之间可任意顺序
5.取出来的元素会附带有扩展方法
a.getAttr(attrName) 取属性
b.setAttr(attrName, attrValue) 设置属性
c.getStyle(styleName) 取样式
d.setStyle(styleName,styleValue) 设置样式
e.getVal() 取值,如果是input,select,textarea取出来的是value的值,其它标签的话取出来的是内嵌html
f.setVal(value) 设置值, 如果是input,select,textarea设置的是value的值,其它标签的话设置的是内嵌html
g.show() 显示元素
h.hide() 隐藏元素
5.AJAX操作使用函数,ajax(type,url,callback,data);
a.type 提交类型
b.url 提交地址
c.callback 回调函数
d.data 待提交数据(a=1&b=2)
6.Cookie操作使用函数,cookie.set(k,v,e) k名称 v值 e有效期(秒) cookie.get(k)
1. [文件] JSTools.js
var JSTools = {version:1.0,author:'lymz',email:'lymz.86@gmail.com'};
var $id = function(id){
return $extend(document.getElementById(id));
};
var $class = function(clas){
return $extend(getElementsByClassName(clas));
};
var $Eclass = function(clas){
var t = $class(clas);
return t.length > 0 ? t[0] : null;
};
var $tag = function(tag){
return $extend(document.getElementsByTagName(tag));
};
var $Etag = function(tag){
var t = $tag(tag);
return t.length > 0 ? t[0] : null;
};
var $dom = function(dom){
var t = dom.split(' ');
var p=null;
for(var i = 0,l = t.length;i < l;++ i) {
if(i > 0 && !p)
break;
else if(i > 0 && p) {
if(p.length != undefined)
p = p[0];
}
var tt = t[i].split('#');
if(tt[0] == 'id')
p = $id(tt[1]);
else if(tt[0] == 'class') {
tt[1] = tt[1].split('|');
if(p)
p = getElementsByClassName(tt[1][0],p);
else
p = $class(tt[1][0]);
if(tt[1][1])
p = $filter(p,tt[1][1]);
} else if(tt[0] == 'tag') {
tt[1] = tt[1].split('|');
if(p)
p = p.getElementsByTagName(tt[1][0]);
else
p = $tag(tt[1][0]);
if(tt[1][1])
p = $filter(p,tt[1][1]);
} else
p = null;
}
return $extend(p);
};
var $filter = function(p,filter){
if(p == null)
return null;
var tt = new Array();
if(filter.indexOf('=') !== -1) {
var t = filter.split('=');
for(var i = 0,j = 0,l = p.length;i < l;++ i) {
if(p[i].getAttribute(t[0]) == t[1])
tt[j++] = p[i];
}
} else if(filter.indexOf('^') !== -1) {
var t = filter.split('^');
for(var i = 0,j = 0,l = p.length;i < l;++ i) {
if(p[i].getAttribute(t[0]).toLowerCase() != t[1].toLowerCase())
tt[j++] = p[i];
}
} else {
for(var i = 0,j = 0,l = p.length;i < l;++ i) {
if(p[i].nodeName.toLowerCase() == filter.toLowerCase())
tt[j++] = p[i];
}
}
return tt;
};
var $Edom = function(dom){
var t = $dom(dom);
if(t != null && t.length != undefined)
return t[0];
else
return t;
};
var $extend = function(object){
if(!object)
return object;
var t = false;
if(object.length == undefined){
object = new Array(object);
t = true;
}
for(var i = 0,l = object.length;i < l;++ i) {
object[i].getAttr = function(attr){return this.getAttribute(attr);};
object[i].setAttr = function(k,v){return this.setAttribute(k,v);};
object[i].getStyle = function(k){return eval('this.style.'+k);};
object[i].setStyle = function(k,v){return eval('this.style.'+k+'=\''+v+'\'');};
object[i].getVal = function(){return this.value!=undefined?this.value:this.innerHTML;};
object[i].setVal = function(v){if(this.value!=undefined)this.value=v;else this.innerHTML=v;return true;};
object[i].show = function(){return this.setStyle('display','block');};
object[i].hide = function(){return this.setStyle('display','none');};
}http://www.enterdesk.com/special/meitu/
object.each=function(func){美图
if(this.length == undefined)
object = new Array(object);
var it = null;
for(var i = 0,l = object.length;i < l;++ i) {
it = object[i];
func(it,i);
}
};
return t ? object[0] : object;
};
var ajax = function(type,url,func,data){
if(window.ActiveXObject){
var xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
} else {
var xmlHttp=new XMLHttpRequest();
}
xmlHttp.open(type,url,true);
xmlHttp.onreadystatechange=function(){
if(xmlHttp.readyState == 4)
if(xmlHttp.status == 200)
if(func) func(xmlHttp.responseText);
};
xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlHttp.send(data?data:null);
};
var cookie = {
get:function(k){
var t = document.cookie.split('; ');
for(var i = 0,l = t.length;i < l;++ i) {
var tt = t[i].split('=');
if(tt[0] == k) {
return decodeURI(tt[1]);
}
}
return undefined;
},
set:function(k,v,e){
if(e) {
var d = new Date();
d.setTime(d.getTime()+(e*1000));
e = ';expires='+d.toGMTString();
} else
e = '';
document.cookie = k + '=' + v + e;
}
};
var getElementsByClassName = function(c,p){
p = p ? p : document;
var arrElements = p.getElementsByTagName('*');
var arrReturnElements = new Array();
c = c.replace(/\-/g, "\\-");
var oRegExp = new RegExp("(^|\\s)" + c + "(\\s|$)");
var oElement;
for(var i=0; i < arrElements.length; i++){
oElement = arrElements[i];
if(oRegExp.test(oElement.className)){
arrReturnElements.push(oElement);
}
}
return arrReturnElements;
};
简单的可兼容所有浏览器的操作html元素的javascript框架的更多相关文章
- 一个简单有效的兼容IE7浏览器的办法
最近发现了一个简单有效的兼容IE7浏览器的办法 直接将下面代码复制道页面 <meta http-equiv="X-UA-Compatible" content="I ...
- 【面试必备】javascript操作DOM元素
前言 时间过的真快,不知不觉就到年底了.问问自己,这一年你对自己的工作满意吗? 评价标准是什么呢?当然是马云的那两条准则了:钱给到了吗?干的爽吗?如果答案都是no,那么,你准备好跳槽了吗? 为了应对年 ...
- 【转】让Bootstrap 3兼容IE8浏览器
FROM : http://www.ijophy.com/2014/05/bootstrap3-compatible-with-ie8.html 最近在研究Bootstrap(官方,Github)这个 ...
- 让Bootstrap 3兼容IE8浏览器
最近在研究Bootstrap(官方,Github)这个优秀的前端框架,Bootstrap最开始是Twitter团队内部的一个前端框架,所谓前端框架就是一个CSS/HTML框架,框架里面有下拉菜单.按钮 ...
- Bootstrap 3兼容IE8浏览器(转)
Bootstrap是一个响应式的布局,你可以在宽屏电脑.普通电脑,平板电脑,手机上都得到非常优秀的布局体验.这种响应式的布局正是通过CSS3的媒体查询(Media Query)功能实现的,根据不同的分 ...
- Zclip复制页面内容到剪贴板兼容各浏览器
Zclip:复制页面内容到剪贴板兼容各浏览器 WEB开发中,要让用户复制页面中的一段代码.URL地址等信息,为了避免用户拖动鼠标再进行右键复制操作而可能出现的差错,我们可以直接在页面中放置一个复制按钮 ...
- js兼容各个浏览器的复制功能
看似简单的复制功能,用js做起来竟然遇到各种情况.刚开始在网上搜索到复制功能的几种实现方法,但是都不兼容.最后还是用的插件代码如下 html模板 <tr> <td>1</ ...
- JavaScript 定义类的最佳写法——完整支持面向对象(封装、继承、多态),兼容所有浏览器,支持用JSDuck生成文档
作者: zyl910 [TOC] 一.缘由 由于在ES6之前,JavaScript中没有定义类(class)语法.导致大家用各种五花八门的办法来定义类,代码风格不统一.而且对于模拟面向对象的三大支柱& ...
- JS兼容各个浏览器的本地图片上传即时预览效果
JS兼容各个浏览器的本地图片上传即时预览效果 很早以前 在工作曾经碰到这么一个需求,当时也是纠结了很久,也是google了很久,没有碰到合适的demo,今天特意研究了下这方面的的问题,所以也就做了个简 ...
随机推荐
- MySQL的备份与恢复具体解释
MySQL数据备份 在mySQL里面,有逻辑备份和物理备份.逻辑备份最大长处是对于各种存储引擎,都能够使用相同的方法来备份. 而物理备份则不同.不同的存储引擎有着不同的备份方法. 逻辑备份与恢复 备份 ...
- 红米note3刷安卓原生
http://www.romzj.com/rom/63404.htm#comments-version 然后在系统设置里升级系统, http://www.lineageosdownloads.com/ ...
- 【Python】使用制表符换行符来添加空白
在编程中,在打印时,有时候需要显示出来的数据看着舒服一点,那么使用制表符(\t).换行符(\n)即可轻松实现 >>> print('zhangsan')zhangsan 加入制表符后 ...
- chm文件打不开的解决办法
我今天在网上找了找C++函数库,下载下来一个 .chm 文件,打开之后发现只显示了目录,内容却显示不出来. 显示是这样:右边区域显示不出来. 在网上查了一下发现CHM文件是网上比较多的电子书籍显示格式 ...
- INSTALL_FAILED_UID_CHANGED解决的方法
近期开发过程中又遇到了这个问题,最终找到了一个比較好的解决的方法.在此记录下. 打开手机或者pad中的设置----->安全----->未知来源(同意安装非安卓市场应用程序). 把这个取消, ...
- Django之站内搜索-Solr,Haystack
java -version 不多说 solr 是java 开发的 java version "1.7.0_79" Java(TM) SE Runtime Environment ( ...
- 在tomcat中用jndi配置数据源启动java web程序
1.在web.xml中添加: <resource-ref> <res-ref-name>jdbc/MTSDB</res-ref-name> <re ...
- XSS前置课程--同源策略
什么是同源策略: 在用户浏览互联网中的网页的过程中,身份和权限的思想是贯穿始终的 同源策略(Same-Origin Policy),就是为了保证互联网之中,各类资源的安全性而诞生的产物,它实际上是一个 ...
- 在IDEA建立Maven的多模块Web项目
由于要搭建的是Maven项目,考虑到后面可能会有扩展,因此项目搭建的分模块的. 下面一步一步的来搭建这个项目 打开IDEA集成开发环境,点击File ---> New ---> Proje ...
- Gunicorn、Supervisor
简介 Gunicorn来源于Ruby的unicorn项目,是一个Python WSGI HTTP Server,通过pre-fork worker模型来管理和维护worker. 简而言之就是通过多进程 ...