var toCamel = function(property) { // 如果沒有 -[a-z] 字母,則直接返回 if ( !patterns.HYPHEN.test(property) ) { " /> 国产成人三级,国产精品网址,精品一二三

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

Javascript YUI 讀碼日記之 YAHOO.util.Dom - Part.3

var patterns = {
    HYPHEN: /(-[a-z])/i,
    ROOT_TAG: /^body|html$/i
};

var toCamel = function(property) {
    // 如果沒有 -[a-z] 字母,則直接返回
    if ( !patterns.HYPHEN.test(property) ) {
        return property;
    }

    // 如果有緩存,直接返回替換后的值
    if (propertyCache[property]) {
        return propertyCache[property];
    }

    // 使用正則替換
    var converted = property;
    while( patterns.HYPHEN.exec(converted) ) {
        converted = converted.replace(RegExp.$1,
                RegExp.$1.substr(1).toUpperCase());
    }

    // 存入緩存
    propertyCache[property] = converted;
    return converted;
};在 YAHOO.util.Dom 中,getStyle 函數(shù)考慮了更多不同瀏覽器兼容性方面的問題,代碼如下

// 使用 W3C DOM 標準的瀏覽器,比如 Firefox、Opera、Safari
if (document.defaultView && document.defaultView.getComputedStyle) {
    getStyle = function(el, property) {
        var value = null;

        // 重命名部分 CSS 樣式名
        if (property == 'float') {
            property = 'cssFloat';
        }

        // 獲取通過 CSS 加上去的屬性
        var computed = document.defaultView.getComputedStyle(el, '');
        if (computed) {
            value = computed[toCamel(property)];
        }

        return el.style[property] || value;
    };
// 如果是 IE 瀏覽器
} else if (document.documentElement.currentStyle && isIE) {
    getStyle = function(el, property) {                         
        switch( toCamel(property) ) {
            // “轉換”名稱為 IE 可以認識的
            case 'opacity' :
                var val = 100;
                try {
                    val = 
                        el.filters['DXImageTransform.Microsoft.Alpha'].opacity;
                } catch(e) {
                    try {
                        val = el.filters('alpha').opacity;
                    } catch(e) {
                    }
                }
                // 百分比
                return val / 100;
            case 'float': 
                property = 'styleFloat'; 
            default: 
                var value = el.currentStyle ? el.currentStyle[property] : null;
                return ( el.style[property] || value );
        }
    };
} else {
    // 獲取內聯(lián)樣式
    getStyle = function(el, property) { return el.style[property]; };
}另外,PPK 在他的 Blog 上的有關 getStyle 的闡述,也很精彩,有興趣的可以去看下。

JavaScript技術Javascript YUI 讀碼日記之 YAHOO.util.Dom - Part.3,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 重温经典频道在线直播| 秀人网小逗逗集免费观看| 许忠| 欲望之夜| 丛林总动员| 姐妹会的秘密电影| 陈程玉| 韩秀云讲经济| 尹海英| 转正意见评语| 永远少年电影免费播放| 李耀| 北京卫视今晚节目表| 人口高质量发展形势与政策论文| 他其实没那么爱你电影| 珂尼娜| 宇宙战队| 我们的母亲叫中国读后感| 龟兔赛跑的故事视频| 七下英语第二单元作文| 小小安妮| 妈在家就在简谱| 同性gay| 黄梅戏龙女全剧播放| 周星驰的全部电影免费观看| 新红楼梦电影| 血糖最怕三种水果| 乱世危情电视剧演员表| 红日歌词完整版| 血色玫瑰电影完整版| 得闲谨制| 四年级第一二单元测试卷答案| 成人一级片视频| 能哥| 林子祥电影| 日韩欧美电影在线| 成龙电影全部电影作品大全| 欧布奥特曼年代记| 男人亲女人下面的视频| 神马伦理电影网| 女同视频在线观看|