1.根据id或class或tag修改样式,样式名是-连接格式的。

function setStyleById(elem, styles){
if(!(elem = $(elem)) return false; for(prop in styles){
if(!styles.hasOwnProperty(prop)) continue; if(elem.style.setProperty){
elem.style.setProperty(prop, styles[prop]);
}else{
elem.style[camelize(prop)] = styles[prop];
}
}
return true;
}
Lily['setStyleById'] = setStyleById; function setStyleByClass(parent, tag, className, styles){
var elements = getElementsByClassName(className, tag, parent);
for(var i = 0; i < elements.length; i++){
setStyleById(elements[i], styles);
}
return true;
}
Lily['setStyleByClass'] = setStyleByClass; function setStyleByTag(tag, styles, parent){
parent = $(parent) || document;
var elements = parent.getElementsByTagName(tag); for(var i = 0; i < elements.length; i++){
setStyleById(elements[i], styles);
}
return true;
}
Lily['setStyleByTag'] = setStyleByTag;

2.获取class数组

function getClassNames(elem){
if(!(elem = $(elem))) return false;
return elem.className.split(/\s+/);
}
Lily['getClassNames'] = getClassNames;

3.判断是否有class

function hasClassName(elem, className){
if(!(elem = $(elem))) return false;
var classNames = getClassNames(elem); for (var i = 0; i < classNames.length; i++) {
if(classNames[i] === className) return true;
} return false;
}
Lily['hasClassName'] = hasClassName;

4.添加一个class

function addClass(elem, className){
if(!(elem = $(elem))) return false;
elem.className += (elem.className? ' ' : '') + className;
return true;
}
Lily['addClass'] = addClass;

5.删除一个class

function removeClassName(elem, className){
if(!(elem = $(elem))) return false;
var classNames = getClassNames(elem);
var length = classNames.length; for (var i = length - 1; i >= 0; i--) {
if(classNames[i] === className) delete classNames[i];
}; elem.className = classNames.join(' ');
return (length == classNames.length) ? false : true;
}
Lily['removeClassName'] = removeClassName;

6.取得一个元素的计算样式

function getComputedStyle(elem, property){
if(!(elem = $(elem)) || !property) return false;
var value = elem.style[camelize(property)]; if(!value){
if(document.defaultView && document.defaultView.getComputedStyle){
var css = document.defaultView.getComputedStyle(elem, null);
value = css ? css.getPropertyValue(property) : null;
}else if(elem.currentStyle){
value = elem.currentStyle[camelize(property)];
}
} return value == "auto" ? '' : value;
}
Lily['getComputedStyle'] = getComputedStyle;

7.渐变动画

function fadeColor(from, to, callback, duration, framesPerSecond){
function doTimeout(color, frame){
setTimeout(function (){
callback(color);
}, (duration * 1000 / framesPerSecond) * frame);
} duration = duration || 1;
framesPerSecond = framesPerSecond || 15 * duration; var frame = 1;
var r, g, b; doTimeout('rgb(' + from.r + ',' + from.g + ',' + from.b + ')', 0); while(frame < framesPerSecond + 1){
r = Math.ceil(from.r * (framesPerSecond - frame)/framesPerSecond + to.r * frame/framesPerSecond);
g = Math.ceil(from.g * (framesPerSecond - frame)/framesPerSecond + to.g * frame/framesPerSecond);
b = Math.ceil(from.b * (framesPerSecond - frame)/framesPerSecond + to.b * frame/framesPerSecond); doTimeout('rgb(' + r + ',' + g + ',' + b + ')', frame++);
}
}

例子

Lily.addEvent(window, "load", function (){
fadeColor({'r': 255, 'g': 255, 'b': 255}, {'r': 0, 'g': 0, 'b': 0}, function (color){
document.body.style.backgroundColor = color;
}, 10, 50);
});

【写一个自己的js库】 5.添加修改样式的方法的更多相关文章

  1. 总结:js中4类修改样式的方法

    前言 最近在写一个扩展右键菜单的插件,既然是插件,想着一步到位,把相关的style样式设置都丢进js文件中,直接加载一个js文件便可以使用该插件,所以今天就研究了下js批量的插入样式的方法,即addS ...

  2. 【写一个自己的js库】 3.添加几个处理字符串的方法

    1.生成重复的字符串 if(!String.repeat){ String.prototype.repeat = function (count){ return new Array(count + ...

  3. 【写一个自己的js库】 2.实现自己的调试日志

    还是本着学习的目的,实现一个自己的调试日志,界面很简单,就是将调试信息显示在页面的正中央,用一个ul包裹,每条信息就是一个li. 1.新建一个myLogger.js文件,将需要的方法声明一下.其中va ...

  4. 【写一个自己的js库】 1.搭个架子先

    最近在看<javascript dom 高级程序设计>,想着跟着里面的代码敲一遍吧,也算是做一下学习笔记吧,所以这不是重新发明轮子,只是个学习的过程. 1.先确定自己的命名空间,并且加入几 ...

  5. 【写一个自己的js库】 4.完善跨浏览器事件操作

    1.阻止冒泡. function stopPropagation(event){ event = event || getEvent(event); if(event.stopPropagation) ...

  6. 仿照jquery封装一个自己的js库(一)

    所谓造轮子的好处就是复习知识点,加深对原版jquery的理解. 本文系笔者学习jquery的笔记,记述一个名为"dQuery"的初级版和缩水版jquery库的实现.主要涉及知识点包 ...

  7. 仿照jquery封装一个自己的js库

    所谓造轮子的好处就是复习知识点,加深对原版jquery的理解.本文系笔者学习jquery的笔记,记述一个名为"dQuery"的初级版和缩水版jquery库的实现.主要涉及知识点包括 ...

  8. Java基础-接口.编写2个接口:InterfaceA和InterfaceB;在接口InterfaceA中有个方法void printCapitalLetter();在接口InterfaceB中有个方法void printLowercaseLetter();然 后写一个类Print实现接口InterfaceA和InterfaceB,要求 方法 实现输出大写英文字母表的功能,printLowerca

    #34.编写2个接口:InterfaceA和InterfaceB:在接口InterfaceA中有个方法void printCapitalLetter():在接口InterfaceB中有个方法void ...

  9. MySql表、字段、库的字符集修改及查看方法

    这篇文章主要介绍了MySql表.字段.库的字符集修改及查看方法,本文分别给们它的修改及查看语句,需要的朋友可以参考下 修改数据库字符集: 代码如下: ALTER DATABASE db_name DE ...

随机推荐

  1. python对真假的判断方式

    一.如下是以下值就认为是假 1.None-->None值 2.False-->False值 3.0-->数值零不管它是int,float还是complex类型 4.'',(),[]- ...

  2. SQL查询 addScalar()或addEntity()

    Hibernate除了支持HQL查询外,还支持原生SQL查询.   对原生SQL查询执行的控制是通过SQLQuery接口进行的,通过执行Session.createSQLQuery()获取这个接口.该 ...

  3. Effective Java2读书笔记-创建和销毁对象(二)

    第3条:用私有构造器或者枚举类型强化Singleton属性 这一条,总体来说,就是讲了一个小技巧,将构造器声明为private,可以实现单例.具体有以下几种实现的方式. ①最传统的单例实现模式,可能有 ...

  4. POP3、SMTP、IMAP和Exchange都是个什么玩意?

    很多时候一直对POP3.SMTP.IMAP和Exchange等迷迷糊糊的.下面就整理说明一下: 当前常用的电子邮件协议有SMTP.POP3.IMAP4,它们都隶属于TCP/IP协议簇,默认状态下,分别 ...

  5. Hadoop: the definitive guide 第三版 拾遗 第十二章 之Hive分区表、桶

    Hive分区表 在Hive Select查询中一般会扫描整个表内容,会消耗很多时间做没必要的工作.有时候只需要扫描表中关心的一部分数据,因此建表时引入了partition概念.分区表指的是在创建表时指 ...

  6. 文档生成工具doxygen+图像生成工具GraphViz

    文档生成工具doxygen+图像生成工具GraphViz 虽然jdk自带的javadoc也很好用,不过使用doxygen+GraphViz 的组合可以生成许多强大的图(类图.协作图.文件包含/被包含图 ...

  7. 在非MFC的win 32程序里面能够使用CString类

    论坛有会员用到了.,今天给大家说说CSring如何在非mfc下的调用第一:先要包含 #include "afx.h" 包含之后会报windows.h重复定义我们需要把这个头文件包含 ...

  8. 提交App,请求Apple加急审核

    转载自:http://blog.csdn.net/showhilllee/article/details/19541493 提交完毕后进入加急审核页面. 链接:https://developer.ap ...

  9. C#实训 打字游戏

    StatusStrip控件 状态条 =进度条+标签 等集合体

  10. 【巧妙算法系列】【UVA 11384】 Help is needed for Dexter 正整数序列

    Help is needed for Dexter Time Limit: 3 Second Dexter is tired of Dee Dee. So he decided to keep Dee ...