zoukankan      html  css  js  c++  java
  • 【转】javascript动态调用css样式表

    之前经常遇见classname、csstext之类的词,却不知道如何用。通常在网页中样式表的调用方法有四种。
    第一是外链,即<link rel="StyleSheet" href = "/control/css/base.css">的形式;
    第二是输入样式表;第三是在网页头部申明,如<head> <style type="text/css">...;
    最后是直接在对象后写样式,即<div style = "80%...;">的形式。我们用脚本调用样式,也要从这几方面入手。
    一、通常情况下,我们可以通过改变外链样式的的href的值实现网页样式的实时切换,也就是“改变模板风格”。这时候我们首先需要赋予需要改变的目标一个id,如
    <link rel = "stylesheet" type="text/css" id="css" href="firefox.css" />
    调用时很简单,如<span on click="javascript:document.getElementById('css').href = 'ie.css'">点我改变样式</span>
    二、局部改变样式,分为改变直接样式,改变className和改变cssText三种。需要注意的是:第一,javascript对大小写十分敏感,className不能够把“N”写成“n”,cssText也不能够把“T”写成“t”,否则无法实现效果。第二,如果改变className,则事先在样式表中申明类,但调用时不要再跟style,像
    document.getElementById('obj').style.className="..."的写法是错误的!
    只能写成:document.getElementById('obj').className="..."
    但是如果用cssText的话,必须加上style,正确的写法是:
    document.getElementById('obj').style.cssText="..."
    改变直接样式我就不必说了,大家记得要写到具体样式即可,如
    document.getElementById('obj').style.backgroundColor="#003366"
    对于新人往往不知道CSS具体样式在javascript怎么写,而且有时候在不同浏览器中要求也不一样。如float在IE中写成styleFloat,在FIREFOX中写成cssFloat,这就需要大家的积累了
    本文来自: 脚本之家(www.jb51.net) 详细出处参考:http://www.jb51.net/article/5161.htm

     

    第一步:在连接样式表的元素里定义一个id,例如

    <link rel="stylesheet" type="text/css" href="css1.css" id="cssid">

    我定义的id是css。

    第二步:写一个js函数,代码如下:

    <script type="text/javascript">
    function change(a){
    var css=document.getElementById("cssid");
    if (a==1)
    css.setAttribute("href","css1.css");
    if (a==2)
    css.setAttribute("href","css2.css");
    if (a==3)
    css.setAttribute("href","css3.css");
    }
    </script>

    这个函数的code可以放在页面的任何地方。

    第三步:为改变页面的样式表的连接添加一个函数的触发事件,代码如下:

    <a href="#" onclick="change(1)">我是第一个css1</a>
    <a href="#" onclick="change(2)">我是第二个css2</a>
    <a href="#" onclick="change(3)">我是第三个css3</a>

    该效果在IE和FF下均测试通过,相信大家看完后因该非常明了,利用这个方法我们可以让浏览者自己选择需要显示的样式表,比如年老者可以选择一个字体较大的样式表。这里需要注意的两点是:

    1. 在这个例子中函数名function后面的名字不能为links或者link,如果为links或者link,样式表将不被改变,具体什么原因我也不大清楚,可能是javascript的保留字符。
    2. 另外如果是改变整个页面的样式,你需要在样式表文件里定义body的高度为100%

    第二种方式

    第一步:在连接样式表的元素里定义一个id,例如
    <link rel="stylesheet" type="text/css" href="css1.css" id="cssid" media="screen">

    第二步:写一个js函数,代码如下:
    <script type="text/javascript">
    function change1(){
    document.getElementById("cssid").href="css1.css";
    }
    function change2() {
    document.getElementById("cssid").href="css2.css";
    }
    function change3(){
    document.getElementById("cssid").href="css3.css";
    }
    </script>


    第三步:为改变页面的样式表的连接添加一个函数的触发事件,代码如下:
         <a href="#" onclick="change1()">我是第一个css1</a>
         <a href="#" onclick="change2()">我是第二个css2</a>
          <a href="#" onclick="change3()">我是第三个css3</a>

    第三种方式:

    <script type="text/javascript">

        function loadjscssfile(filename, filetype) {
            if (filetype == "js") { //判断文件类型
                var fileref = document.createElement('script')//创建标签
                fileref.setAttribute("type", "text/javascript")//定义属性type的值为text/javascript
                fileref.setAttribute("src", filename)//文件的地址
            }
            else if (filetype == "css") { //判断文件类型
                var fileref = document.createElement("link")
                fileref.setAttribute("rel", "stylesheet")
                fileref.setAttribute("type", "text/css")
                fileref.setAttribute("href", filename)
            }
            if (typeof fileref != "undefined")
                document.getElementsByTagName("head")[0].appendChild(fileref)
        }

        //loadjscssfile("myscript.js", "js") //打开页面时浏览器动态的加载文件
        loadjscssfile("css/shop.css", "css")

      

        var rl=<%=(String)ViewState["col"]%>;

        var k = "";
        switch(rl)
        {
           case 1:
               k = "1.css";
               break;
     case 2:
               k = "2.css";
               break;

    }

     
     

        loadjscssfile(k, "css") //打开页面时浏览器动态的加载.css 文件


        var filesadded = "" //保存已经绑定文件名字的数组变量
        function checkloadjscssfile(filename, filetype) {
            if (filesadded.indexOf("[" + filename + "]") == -1) {// indexOf判断数组里是否有某一项
                loadjscssfile(filename, filetype)
                filesadded += "[" + filename + "]" //把文件名字添加到filesadded
            }
            else
                alert("file already added!")//如果已经存在就提示
        }

    </script>

  • 相关阅读:
    AWR
    geth入门命令和miner.start返回null的问题
    以太坊geth区块链私链建立
    Ubuntu无法找到add-apt-repository问题的解决方法
    Truffle测试框架
    TypeError: Data location must be "memory" for return parameter in function, but none was given.
    详解 Solidity 事件Event
    以太坊 Geth 环境搭建(Ubuntu)
    智能合约调试指南
    Truffle Smart Contract Error: Invalid number of parameter
  • 原文地址:https://www.cnblogs.com/lavenderzh/p/1759995.html
Copyright © 2011-2022 走看看