Rumah >hujung hadapan web >tutorial js >Javascript从外部动态引入样式和文件的用法详解

Javascript从外部动态引入样式和文件的用法详解

伊谢尔伦
伊谢尔伦asal
2017-07-21 09:24:192846semak imbas

javascript插入样式在前端开发中应用比较广泛,特别是在修改前端表现和页面换肤的时候。

一般情况下javascript动态插入样式有两种,一种页面中引入外部样式,在93f0f5c25f18dab9d176bd4f6de5d30e中使用2cdf5bf648cf2f33323966d7f58a7f3f标签引入一个外部样式文件,另一种是在页面中使用c9ccee2e6ea535a969eb3f532ad9fe89标签插入页面样式(这里说的不是style属性)。

一、页面中引入外部样式:

在93f0f5c25f18dab9d176bd4f6de5d30e中使用2cdf5bf648cf2f33323966d7f58a7f3f标签引入一个外部样式文件,这个比较简单,各个主流浏览器也不存在兼容性问题:

function includeLinkStyle(url) {
 var link = document.createElement("link");
 link.rel = "stylesheet";
 link.type = "text/css";
 link.href = url;
 document.getElementsByTagName("head")[0].appendChild(link);
}

直接用引入一个外部样式文件似乎不合适,所以选择了第二种方案,在页面中使用c9ccee2e6ea535a969eb3f532ad9fe89标签插入页面样式。

二、使用c9ccee2e6ea535a969eb3f532ad9fe89标签插入页面样式:

这种方式在各个主流浏览器存在兼容性问题,像firefox等标准浏览器无法直接获取设置styleSheet的cssText值,标准浏览器下只能使用document.styleSheets[0].cssRules[0].cssText单个获取样式;同时使用:document.styleSheets[0].cssRules[0].cssText=newcssText;页面不会自动更新样式,必须使用:document.styleSheets[0].cssRules[0].style.cssText=newcssText;这点似乎没坑爹的IE来的人性化和简便。YUI中使用了一个很好的办法:style.appendChild(document.createTextNode(styles));采用createTextNode将样式字符串添加到c9ccee2e6ea535a969eb3f532ad9fe89标签内;

function includeStyleElement(styles, styleId) {
    if (document.getElementById(styleId)) {
        return
    }
    var style = document.createElement("style");
    style.id = styleId;
    //这里最好给ie设置下面的属性
    /*if (isIE()) {
style.type = "text/css";
style.media = "screen"
}*/
    (document.getElementsByTagName("head")[0] || document.body).appendChild(style);
    if (style.styleSheet) { //for ie
        style.styleSheet.cssText = styles;
    } else { //for w3c
        style.appendChild(document.createTextNode(styles));
    }
}
var styles = "#div{background-color: #FF3300; color:#FFFFFF }";
includeStyleElement(styles, "newstyle");

这样页面中的元素就能直接应用样式了,不管你的这些元素是不是通过脚本追加的。

Atas ialah kandungan terperinci Javascript从外部动态引入样式和文件的用法详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn