Как настроить переключатель CSS - PullRequest
24 голосов
/ 07 августа 2008

Я работаю над сайтом, который переключится на новый стиль в установленную дату. Сайт построен в семантическом HTML и CSS, поэтому для изменения нужно просто изменить ссылку CSS. Я работаю с дизайнером, который должен уметь видеть, как он выглядит, а также с клиентом, который должен иметь возможность просматривать обновления содержимого в текущем виде, а также прогресс в разработке нового вида. *

Я планирую использовать магическое значение строки запроса и / или ссылку javascript в нижнем колонтитуле, которая записывает файл cookie для выбора новой страницы CSS. Мы работаем в ASP.NET 3.5. Любые рекомендации?

Следует отметить, что мы используем условные комментарии IE для поддержки IE8, 7 и 6. Я могу создать функцию, которая выполняет замену:

<link href="Style/<% GetCssRoot() %>.css" rel="stylesheet" type="text/css" />
<!--[if lte IE 8]>
    <link type="text/css" href="Style/<% GetCssRoot() %>-ie8.css" rel="stylesheet" />
<![endif]-->
<!--[if lte IE 7]>
    <link type="text/css" href="Style/<% GetCssRoot() %>-ie7.css" rel="stylesheet" />
<![endif]-->
<!--[if lte IE 6]>
    <link type="text/css" href="Style/<% GetCssRoot() %>-ie6.css" rel="stylesheet" />
<![endif]-->

Ответы [ 4 ]

15 голосов
/ 07 августа 2008

В Asp.net 3.5 вы должны иметь возможность установить тег Link в заголовке как тег сервера. Затем в codebehind вы можете установить свойство href для элемента link на основе значения cookie, строки запроса, даты и т. Д.

В вашем файле aspx:

<head>
  <link id="linkStyles" rel="stylesheet" type="text/css" runat="server" />
</head>

А в Коде позади:

protected void Page_Load(object sender, EventArgs e) {
  string stylesheetAddress = // logic to determine stylesheet
  linkStyles.Href = stylesheetAddress;
}
5 голосов
/ 07 августа 2008

Вы должны изучить ASP.NET темы, это именно то, для чего они используются Они также позволяют создавать элементы управления скинами, что означает предоставление им набора атрибутов по умолчанию.

1 голос
/ 07 августа 2008

Я бы предложил сохранить выбор таблицы стилей в сеансе, чтобы вам не приходилось полагаться на наличие ключа строки запроса, присутствующего постоянно Вы можете проверить сеанс в Page_Load и добавить соответствующую ссылку на таблицу стилей. Похоже, это временная ситуация / ситуация с разработкой, так что делайте все, что легко и работает.

if (!String.IsNullOrEmpty(Request.QueryString["css"]))
  Session.Add("CSS",Request.QueryString["css"]);
0 голосов
/ 07 августа 2008

Я бы сделал следующее:

www.website.com /? = Таблица стилей new.css

Тогда в вашем коде ASP.NET:

if (Request.Querystring["stylesheet"] != null) {
    Response.Cookies["stylesheet"].Value = Request.QueryString["stylesheet"];
    Response.Redirect(<Current Page>);
}

Тогда где вы определяете свои таблицы стилей:

if (Request.Cookies["stylesheet"] != null) {
    // New Stylesheet
} else {
    // Default
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...