zoukankan      html  css  js  c++  java
  • 【写一个自己的js库】 5.添加修改样式的方法

    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);
            });
  • 相关阅读:
    内联函数和宏
    C++内联函数与宏定义
    C++函数声明和定义深度解析
    C++中的头文件和源文件
    国外程序员整理的 C++ 资源大全
    c语言中的字符数组与字符串
    iOS应用架构谈(二):View层的组织和调用方案(中)
    iOS应用架构谈(一):架构设计的方法论
    解决xib约束冲突
    tableView设置首尾
  • 原文地址:https://www.cnblogs.com/pandabunny/p/4774096.html
Copyright © 2011-2022 走看看