项目里要添加 custom css 功能 (dynamic stylesheet ),总结一下实现方法。
1。在JSP中动态设定文件path
预先生成一些css文件,由用户选择,在jsp被请求时,动态加载用户选择的css文件。
- <link rel="STYLESHEET" type="text/css" href="css file" >
<link href="动态设定样式文件" type="text/css" rel="STYLESHEET">
这种方法,网上讲很多。
2。覆盖CSS样式
利用CSS的一个特点,即当有重名样式时,新的样式内容将覆盖旧的,对使用样式的元素来说,就是使用就近的样式内容。
所以,我们可以在中引用一个默认的样式文件,然后,将客户订制的CSS样式,动态输出到JSP的
<link href="默认样式文件" type="text/css" rel="STYLESHEET">
- <link rel="STYLESHEET" type="text/css" href="default css file" >
- <style type="text/css">
- style>
之中,这样客户订制的css就会覆盖默认样式。
3。使用jsp来动态生成CSS
将css样式文件,改名为.jsp,引用样式文件时,使用这个jsp文件,就可以动态生成样式了。mycss.jsp如下
- <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %>
- <%
- request.setAttribute("baseColor", request.getParameter("baseColor"));
- request.setAttribute("color", request.getParameter("color"));
- %>
- .myColor {
- color: <c:out value="${color}" default="#003399"/>;
- background-color: <c:out value="${baseColor}" default="#cfddee"/>;
- }
在jsp中引用
- <link rel="STYLESHEET" type="text/css" href="/mycss.jsp?baseColor=red&color=blue" >
因为link标签,不能把 request 也传过去,所以要通过url传参数,也可以通过session。
本文介绍三种在项目中实现定制CSS样式的方案:1. 在JSP中动态设置文件路径;2. 利用CSS覆盖特性;3. 使用JSP动态生成CSS。这些方法可以帮助开发者灵活地调整网站样式。

被折叠的 条评论
为什么被折叠?



