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. winform 窗口点击窗体任意位置移动窗体

    private bool _isDown; private Point _mousePoint; private void Users_MouseDown(object sender, MouseEv ...

  2. 在Cocos2d-X中新建Android项目

    Windows下创建Cocos2d-X的Android项目并不复杂,关键是要改几个环境变量 一.进入Cocos2d-X主目录修改“create-android-project.bat” 大家都知道要点 ...

  3. 添加鼠标右键菜单项(EditPlus为例)

    下载Editplus,发现大多是绿色版,这就导致鼠标右键快捷菜单了,使用起来不方面,上网搜集了下资料,解决方法很简单: 首先进入注册表:regedit 然后如图设置新项. 其中editplus是右键菜 ...

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

    第7条:避免使用终结方法 这一条讲的简直是不知所云.先简单记下来其中说出的几条: ①显式终止方法的典型例子有InputStream.OutputStream和java.sql.Connection上的 ...

  5. Ext.getCmp()的简单使用

    Ext.getCmp(Ext组件ID),根据Ext组件的ID选择EXT组件. 例如:点击Panel->toolbar上的button改变Panel的标题 Ext.onReady(function ...

  6. web技术之图片预加载

    http://www.cnblogs.com/rt0d/archive/2011/04/17/2018646.html http://www.oschina.net/code/snippet_5437 ...

  7. 主要协议SCSI、FC、iSCSI

    一.SCSI SCSI是小型计算机系统接口(Small Computer System Interface)的简称,于1979首次提出,是为小型机研制的一种接口技术,现在已完全普及到了小型机,高低端服 ...

  8. WPF笔记(1.8 资源与映射)——Hello,WPF!

    原文:WPF笔记(1.8 资源与映射)--Hello,WPF! 终于,看明白了,已经是凌晨1:39分.这本书这一节写得实在是不好,一个local搞得我糊里糊涂,于是,准备按照他的思路,按照我的理解,改 ...

  9. SQL Server索引 - 索引(物化)视图 <第九篇>

    一.索引视图基本概念 索引视图实际上是一种将一组唯一值“物化”为群集索引形式的视图,所为物化就是几乎和表一样,其数据也是会存储一份的(会占用硬盘空间,但是查询速度快,例如可以将count(),sum( ...

  10. Safari HTML5 Canvas Guide: Creating Charts and Graphs

    Safari HTML5 Canvas Guide: Creating Charts and Graphs Bar graphs are similar to data plots, but each ...