zoukankan      html  css  js  c++  java
  • 深入理解脚本化CSS系列第五篇——动态样式

    前面的话

      很多时候,DOM操作比较简单明了,因此用javascript生成那些通常原本是HTML代码生成的内容并不麻烦。但由于浏览器充斥着隐藏的陷阱和不兼容问题,处理DOM中的某些部分时要复杂一些,比如动态样式就相对较复杂

      所谓动态样式,是指在页面加载时并不存在,在页面加载完成后动态添加到页面的样式

      动态样式包括两种情况:一种是通过<link>元素插入外部样式表,另一种是通过<style>元素插入内部样式。下面将详细介绍这两种情况

    外部样式

    /*style.css里面的内容*/
    .box{height:100px;100px;background-color: pink;}
    var link = document.createElement("link");
    link.rel = "stylesheet";
    link.type = "text/css";
    link.href = "style.css";
    var head = document.getElementsByTagName('head')[0];
    head.appendChild(link);

      使用函数封装如下:

    <div class="box">测试文字</div>
    <button id="btn">动态添加样式</button>
    <script>
    function loadStyles(url){
        loadStyles.mark = 'load';
        var link = document.createElement("link");
        link.rel = "stylesheet";
        link.type = "text/css";
        link.href = url;
        var head = document.getElementsByTagName('head')[0];
        head.appendChild(link); 
    }
    btn.onclick = function(){
        if(loadStyles.mark != 'load'){
            loadStyles("style.css");        
        }
    }
    </script>

    内部样式

    var style = document.createElement("style");
    style.type = "text/css";
    style.innerHTML = ".box{height:100px;100px;background-color: pink;}";
    var head = document.getElementsByTagName('head')[0];
    head.appendChild(style); 

      使用函数封装如下:

    <div class="box">测试文字</div>
    <button id="btn">动态添加样式</button>
    <script>
    function loadStyles(str){
        loadStyles.mark = 'load';
        var style = document.createElement("style");
        style.type = "text/css";
        style.innerHTML = str;
        var head = document.getElementsByTagName('head')[0];
        head.appendChild(style); 
    }
    btn.onclick = function(){
        if(loadStyles.mark != 'load'){
            loadStyles(".box{height:100px;100px;background-color: pink;}");        
        }
    }
    </script>

      [注意]该方法在IE8-浏览器中报错,因为IE8-浏览器将<style>视为当作特殊的节点,不允许访问其子节点或设置innerHTML属性

    兼容写法

      动态插入内部样式时,存在兼容问题,下面有两种兼容处理办法

    兼容一

      IE浏览器支持访问并修改元素的CSSStyleSheet对象的cssText属性,通过修改该属性可实现类似效果

    <div class="box">测试文字</div>
    <button id="btn">动态添加样式</button>
    <script>
    function loadStyles(str){
        loadStyles.mark = 'load';
        var style = document.createElement("style");
        style.type = "text/css";
        try{
            style.innerHTML = str;
        }catch(ex){
            style.styleSheet.cssText = str;
        }
        var head = document.getElementsByTagName('head')[0];
        head.appendChild(style); 
    }
    btn.onclick = function(){
        if(loadStyles.mark != 'load'){
            loadStyles(".box{height:100px;100px;background-color: pink;}");        
        }
    }
    </script>    

    兼容二

      作用域元素是微软自己的一个定义,一般来说页面中看到的元素是有作用域的元素,页面中看不到的元素就是无作用域的元素 

      在IE8-浏览器中,<style>元素是一个没有作用域的元素,如果通过innerHTML插入的字符串开头就是一个无作用域的元素,那么IE8-浏览器会在解析这个字符串前先删除该元素

      所以,下面这段代码是无效的

    div.innerHTML = '<style>div{height:100px;}</style>';

      于是,可以通过增加一个'_'文本节点,然后再删除使之有效

        div.innerHTML = "_<style>div{height:100px;}</style>";
        div.removeChild(div.firstChild);
    <div class="box">测试文字</div>
    <button id="btn">动态添加样式</button>
    <script>
    function loadStyles(str){
        loadStyles.mark = 'load';
        var div = document.createElement("div");
        div.innerHTML = '_' + '<style>' + str+'</style>';
        div.removeChild(div.firstChild);
        var head = document.getElementsByTagName('head')[0];
        head.appendChild(div.firstChild); 
        div = null;
    }
    btn.onclick = function(){
        if(loadStyles.mark != 'load'){
            loadStyles(".box{height:100px;100px;background-color: pink;}");        
        }
    }
    </script>

  • 相关阅读:
    进程、线程和协程的区别(转)
    IO多路复用机制(转)
    防火墙及其功能(转)
    TCP连接的建立和终止。
    TCP和UDP细致刻画,区别。
    typename T和class T区别与联系
    TCP UDP的详解开始 ----UNIX网络编程
    关于UNIX网络编程的的OSI,1.7章的总结
    UNIX网络编程daytime服务端和客户端的实现过程
    linux shell脚本执行错误:bad substitution
  • 原文地址:https://www.cnblogs.com/xiaohuochai/p/5851203.html
Copyright © 2011-2022 走看看