【JavaScript 封装库】Prototype 原型版发布!
/*
源码作者: 石不易(Louis Shi)
联系方式: http://www.shibuyi.net
===================================================================================================
程序名称: JavaScript 封装库 Prototype 版
迭代版本: 无
功能总数: 14 个
功能介绍:
1. 实现代码连缀
2. id / name / tagName / class 节点获取
3. class 选择器添加与移除
4. css 规则添加与移除
5. 设置与获取元素内部文本
6. 设置与获取css
7. 实现 click 事件
*/ // 实例化入口
function $() {
return new Base();
} // 封装库构造方法
function Base() {
this.elements = [];
} // 获取id元素节点
Base.prototype.getId = function (id) {
this.elements.push(document.getElementById(id));
return this;
}; // 获取name元素节点
Base.prototype.getName = function (name, position) {
if (typeof position != 'undefined') { // 局部
var nodes = $().getTagName('*', position).elements;
for (var i = 0; i < nodes.length; i ++) {
if (nodes[i].getAttribute('name') == name) this.elements.push(nodes[i]);
}
} else { // 全局
var nodes = document.getElementsByName(name);
for (var i = 0; i < nodes.length; i ++) {
this.elements.push(nodes[i]);
}
}
return this;
}; // 获取tagName元素节点
Base.prototype.getTagName = function (tagName, position) {
if (typeof position != 'undefined') { // 局部
var nodes = $().getId(position).elements[0].getElementsByTagName(tagName);
} else { // 全局
var nodes = document.getElementsByTagName(tagName);
}
for (var i = 0; i < nodes.length; i ++) {
this.elements.push(nodes[i]);
}
return this;
}; // 获取class元素节点
Base.prototype.getClass = function (className, position) {
if (typeof position != 'undefined') { // 局部
var nodes = $().getTagName('*', position).elements;
} else { // 全局
var nodes = $().getTagName('*').elements;
}
for (var i = 0; i < nodes.length; i ++) {
if (nodes[i].className == className) this.elements.push(nodes[i]);
}
return this;
}; // 获取与设置innerHTML
Base.prototype.html = function (text) {
if (typeof text != 'undefined') { // 设置
for (var i = 0; i < this.elements.length; i ++) {
this.elements[i].innerHTML = text;
}
} else { // 获取
var html = [];
for (var i = 0; i < this.elements.length; i ++) {
html.push(this.elements[i].innerHTML);
}
return html;
}
return this;
}; // 获取与设置CSS
Base.prototype.css = function (cssKey, cssValue) {
if (typeof cssValue != 'undefined' || cssKey instanceof Array) { // 设置
for (var i = 0; i < this.elements.length; i ++) {
if (cssKey instanceof Array) {
var _cssKye, _cssValue, _css;
for (var j = 0; j < cssKey.length; j ++) {
if (cssKey[j].match(/([a-z]+)\s*=\s*([\w#]+)/i) != null) { // ['color=red', 'backgroundColor = green']
_css = cssKey[j].split(/\s*=\s*/);
_cssKey = _css[0];
_cssValue = _css[1];
this.elements[i].style[_cssKey] = _cssValue;
}
}
} else {
this.elements[i].style[cssKey] = cssValue;
}
}
} else { // 获取
var css = [];
for (var i = 0; i < this.elements.length; i ++) {
if (typeof window.getComputedStyle != 'undefined') { // W3C
css.push(window.getComputedStyle(this.elements[i], null)[cssKey]);
} else if (typeof this.elements[i].currentStyle != 'undefined') { // IE 6/7/8
css.push(this.elements[i].currentStyle[cssKey]);
}
}
return css;
}
return this;
}; // 检测class选择器
Base.prototype.hasClass = function (className) {
var results = [];
for (var i = 0; i < this.elements.length; i ++) {
results.push(!!this.elements[i].className.match(new RegExp('(\\s|^)' + className + '(\\s|$)')));
}
return results;
}; // 添加class选择器
Base.prototype.addClass = function (className) {
var space = '';
var results = this.hasClass(className);
for (var i = 0; i < results.length; i ++) {
if (!results[i]) {
if (this.elements[i].className != '') space = ' ';
this.elements[i].className += space + className;
}
}
return this;
}; // 移除class选择器
Base.prototype.removeClass = function (className) {
var results = this.hasClass(className);
for (var i = 0; i < results.length; i ++) {
if (results[i]) this.elements[i].className = this.elements[i].className.replace(new RegExp('(\\s|^)' + className + '(\\s|$)'), '');
}
return this;
}; // 添加样式规则Rule
Base.prototype.addRule = function (ruleName, ruleText, index, position) {
if (typeof index == 'undefined') index = 0;
if (typeof position == 'undefined') position = 0;
var sheet = document.styleSheets[index];
if (typeof sheet != 'undefined') {
if (typeof sheet.insertRule != 'undefined') { // W3C
sheet.insertRule(ruleName + ' {' + ruleText + '}', position);
} else if (sheet.addRule != 'undefined') { // IE 6/7/8
sheet.addRule(ruleName, ruleText, position);
}
}
return this;
}; // 移除样式规则Rule
Base.prototype.removeRule = function (index, position) {
if (typeof index == 'undefined') index = 0;
if (typeof position == 'undefined') position = 0;
var sheet = document.styleSheets[index];
if (typeof sheet != 'undefined') {
if (typeof sheet.deleteRule != 'undefined') { // W3C
sheet.deleteRule(position);
} else if (typeof sheet.removeRule != 'undefined') { // IE 6/7/8
sheet.removeRule(position);
}
}
return this;
}; // 鼠标 click 事件
Base.prototype.click = function (method) {
if (method instanceof Function) {
for (var i = 0; i < this.elements.length; i ++) {
this.elements[i].onclick = method;
}
}
return this;
};
关于 Prototype 原型版核心源码与实例演示的获取请移动至官网下载!
感谢大家积极评测给予意见!
CNBlogs 博客:http://www.cnblogs.com/shibuyi/
CSDN 博客:http://blog.csdn.net/louis_shi/
ITeye 博客:http://shibuyi.iteye.com/
【JavaScript 封装库】Prototype 原型版发布!的更多相关文章
- 【PHP 模板引擎】Prototype 原型版发布!
在文章的开头,首先要向一直关注我的人说声抱歉!因为原本是打算在前端框架5.0发布之后,就立马完成 PHP 模板引擎的初版.但我没能做到,而且一直拖到了15年元旦才完成,有很严重的拖延症我很惭愧,再次抱 ...
- 【JavaScript 封装库】BETA 5.0 测试版发布!
JavaScript 前端框架(封装库) BETA 5.0 已于10月10日正式发布,今天开始提供 BETA 5.0 的 API 参考文献.相较于之前 5 个版本的发布都是草草的提供源代码,并没有很多 ...
- 【JavaScript 封装库】BETA 3.0 测试版发布!
/* 源码作者: 石不易(Louis Shi) 联系方式: http://www.shibuyi.net =============================================== ...
- 【JavaScript 封装库】BETA 2.0 测试版发布!
/* 源码作者: 石不易(Louis Shi) 联系方式: http://www.shibuyi.net =============================================== ...
- 【JavaScript 封装库】BETA 1.0 测试版发布!
/* 源码作者: 石不易(Louis Shi) 联系方式: http://www.shibuyi.net =============================================== ...
- 【JavaScript 封装库】BETA 4.0 测试版发布!
/* 源码作者: 石不易(Louis Shi) 联系方式: http://www.shibuyi.net =============================================== ...
- 【PHP 基础类库】Prototype 原型版教学文章!
前言 大家好我是:石不易,今天我为大家带来了PHP基础类库原型版的教学文章,至此本人的作品线已分为三大类,分别是:JavaScript前端框架(封装库).PHP模板引擎.以及PHP基础类库.该类库历时 ...
- javascript中的prototype(原型)认识
prototype实现了对象与对象的继承,在JS中变量,函数,几乎一切都是对象,而对象又有_ptoro_属性,这个属性就是通常说的原型,是用来指向这个对象的prototype对象,prototype对 ...
- 【JavaScript】关于prototype原型的一些链接
http://www.cnblogs.com/slowsoul/archive/2013/05/30/3107198.html http://www.thinksaas.cn/group/topic/ ...
随机推荐
- datetimepicker使用
常考地址:http://www.bootcss.c 直接上代码: 步骤:1.http://www.bootcss.com/p/bootstrap-datetimepicker/下载包 2.将里面的js ...
- eclipse 离线安装STS插件
1.下载 eclipse Version: 2018-12 (4.10.0) 下载sts相应版本:https://spring.io/tools3/sts/all 2.安装 Help->Inst ...
- java——平衡二叉树 AVLTree、AVLMap、AVLSet
平衡二叉树:对于任意一个节点,左子树和右子树的高度差不能超过1 package Date_pacage; import java.util.ArrayList; public class AVLTre ...
- XGBoost算法
一.基础知识 (1)泰勒公式 泰勒公式是一个用函数在某点的信息描述其附近取值的公式.具有局部有效性. 基本形式如下: 由以上的基本形式可知泰勒公式的迭代形式为: 以上这个迭代形式是针对二阶泰勒展开,你 ...
- python3+Appium自动化13-H5元素定位实践案例
测试场景 启动钉钉app进入工作H5页面,点击考勤签到 查看webview上元素 1.电脑上打开chrome浏览器输入:chrome://inspect/#devices 2.Discover USB ...
- 断路器hystrix
分布式系统中不可避免的会出现一些故障,因为服务间错综复杂的依赖关系,有时候一个服务出现问题后,会导致依赖于它的服务出现远程调度的线程受阻,给服务造成压力,当然同样的,祖父级调用者(暂且这么叫吧)当然也 ...
- JavaScript高级程序设计--对象创建的三种方法
创建对象的三种方法: 1.工厂模式 工厂模式是软件工程领域广为人知的设计模式,这种模式抽象了创建具体对象的过程.下面是使用工厂函数创建对象的的一个例子. 2.构造函数: 从上面的例子中,我们看到构造函 ...
- 如何有效防止DEDE织梦系统被挂木马安全设置(仅供参考)
尊敬的客户,您好! 感谢广大客户对我司工作的信任和支持! 我司在最近的一个多月内陆续发现多起因 DedeCMS 安全漏洞造成网站被上传恶意脚本的事件,入侵者可利用恶意脚本对外发送大量 ...
- Android串口操作,简化android-serialport-api的demo(转载)
原帖地址:点击打开 最近在做android串口的开发,找到一个开源的串口类android-serialport-api.其主页在这里http://code.google.com/p/android-s ...
- html学习笔记(一)div的透明设置
要使得div的透明度设置,有两种方法. 第一种:使用opacity属性,单词的意思是不透明性,你可以设置它的值,范围是0到1,1为不透明,0为全透明.具体使用如下: css代码: #div01{ ba ...