0

$cat在 URL 中有一个名为(代表“类别”)的变量。

根据它是“a”还是“b”,我使用链接交换样式表:

<?php
if($cat == "a") { ?> 
   <link rel="stylesheet" href="/css/styleA.css"> 
<?php }
elseif($cat == "b") { ?>
   <link rel="stylesheet" href="/css/styleB.css"> 
<?php } ?>

styleA.css 使background-color标题的蓝色变成蓝色,而 styleB.css 使它变成红色

<div id="header" data-role="header" data-position='fixed'>...</div>

如果我单击如下所示的链接:

<a href="index.php?cat=a">Click for red</a>
<a href="index.php?cat=b">Click for blue</a>

URL 确实有效(内容取决于 $cat),我确实得到了 $cat 的值,但样式表似乎没有交换,因为颜色没有改变。但是,如果我重新加载页面(使用之前链接给出的 URL)样式表交换并且一切正常。

我对正在开发的网站的桌面版本使用了相同的方法,并且一切正常。这个问题似乎只有在我使用 jquery mobile 时才会出现。

有谁明白为什么这不能正常工作?

编辑(添加 html):这几乎是它,但这是其余的:

头部:

<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<meta name="viewport" content="initial-scale=1.0, user-scalable=no">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<title></title>
<link rel="stylesheet" href="https://d10ajoocuyu32n.cloudfront.net/mobile/1.3.1/jquery.mobile-1.3.1.min.css">
<!-- Extra Codiqa features -->
<link rel="stylesheet" href="/css/codiqa.ext.css">
<link rel="stylesheet" href="/css/style.css">
<?php if($cat == "a") { ?>  <link rel="stylesheet" href="/css/styleASS.css"> <?php } 
      if($cat == "b")   { ?> <link rel="stylesheet" href="/css/styleBB.css"> <?php }
?>
<!-- jQuery and jQuery Mobile -->
<script src="https://d10ajoocuyu32n.cloudfront.net/jquery-1.9.1.min.js"></script>
<script src="https://d10ajoocuyu32n.cloudfront.net/mobile/1.3.1/jquery.mobile-1.3.1.min.js"></script>
<!-- Extra Codiqa features -->
<script src="https://d10ajoocuyu32n.cloudfront.net/codiqa.ext.js"></script>
</head>


<div data-role="page" id="page">
   <div id="panel_menu" data-role="panel" data-display="overlay">
        <ul data-role="listview">
            <li role="heading">Navigation</li>
            <li><a href="#">Home</a></li>
            <li><a href="#">Products</a></li>
            <li><a href="#">Service</a></li>
            <li><a href="#">Contact</a></li>
            <li><a href="#">Login</a></li>
        </ul>
    </div>
    <div id="header" data-role="header" data-position='fixed'>
        <h1>Header</h1>
        <a href="#panel_menu">Menu</a>
    </div>
     <div data-role="content">

     <?php include "$menu_page_content";?>

     <a href="?cat=a&lang=en&menu=home">a</a>
      <a href="?cat=b&lang=en&menu=home">b</a>

    </div>
    <div data-role="footer" data-position="fixed" data-theme="d">
        <div data-role="navbar" class="ui-icon-nodisc">
          <ul>
            <li><a href="#" id='language' data-icon='custom'>Change Language</a></li>
            <li><a href="#" id='category' data-icon="custom" >Change Category</a></li>
            <li><a href="#" id='contact' data-icon="custom" >Contact</a></li>
          </ul>
        </div>
    </div>
</div><!-- page -->

编辑:将其上传到免费主机:在这里 您可以单击内容区域中的链接之一,或单击页脚区域中的“类别”。单击并重新加载页面。

4

2 回答 2

1

这必须取决于数据在您使用的浏览器上的缓存方式。

几种解决方案是可能的。

您不能交换 CSS 样式表,而是使用 PhP 或 Javascript 添加样式属性。这样你就可以 100% 确定它会改变。(顺便说一句,只要用户有 javascript,PhP 就可以做到 100% 确定)

或者强制浏览器每次都重新加载 CSS 表格,但这不是带宽友好的解决方案,我不建议这样做。


如果您想使用它来保存用户的选择并每次重新加载正确的背景,请看一下: http ://www.dynamicdrive.com/forums/archive/index.php/t-44389.html

虽然没有找到任何 SO 链接

于 2013-08-27T13:28:06.783 回答
1

如果您的大多数样式除了颜色之外都是相同的,我建议将它们放在一个样式表中并在一个类中写入正文。

例如

 .header {
      /* general header styles margins paddings and whatnot */
 }

 .cat-a .header {
      background-color: red;
 }
 .cat-b .header {
      background-color: blue;
 }

然后在body上可变写class

 <body class='cat-<?php echo $cat; ?>'>
于 2013-08-27T14:07:32.553 回答