之前经常遇见classname、csstext之类的词,却不知道如何用。通常在网页中样式表的调用方法有四种。
第一是外链,即<link rel="StyleSheet" href = "/control/css/base.css">的形式;
第二是输入样式表;第三是在网页头部申明,如<head> <style type="text/css">...;
最后是直接在对象后写样式,即<div style = "width:80%...;">的形式。我们用脚本调用样式,也要从这几方面入手。
一、通常情况下,我们可以通过改变外链样式的的href的值实现网页样式的实时切换,也就是“改变模板风格”。这时候我们首先需要赋予需要改变的目标一个id,如
<link rel = "stylesheet" type="text/css" >http://www.jb51.net/article/5161.htm

 

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

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

我定义的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" >第三种方式:

<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>

相关文章: