Преимущества / недостатки использования XSL для рендеринга целых веб-страниц

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

Помогите мне стать менее невежественным, что может быть причиной этого? Какие преимущества или недостатки это приносит?

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
12
0
10 298
7
Перейти к ответу Данный вопрос помечен как решенный

Ответы 7

Похоже, они сделали это, потому что они очень хорошо знали XSL-T и уже имели под рукой XML-данные.

Сам я бы не хотел этого решения. XSL-T - не самая простая вещь для чтения или записи. Он не подходит для визуализации того, как будет выглядеть страница. Это исключает дизайнеров и веб-разработчиков. И это плохо интернационализируется. Нет ничего эквивалентного пакетам ресурсов Java, которые могут извлекать информацию, специфичную для локали. Я не считаю вырезание и вставку хорошим решением.

Ответ принят как подходящий

На стороне сервера:

Advantages:
  • Чистые, лаконичные шаблоны
  • Простой способ преобразовать данные XML в HTML
  • Достаточно быстро
Disadvantages:
  • Модель программирования незнакома и неудобна для многих программистов, использующих процедурный язык.
  • Неудобно, если некоторые или все исходные данные представляют собой нет в XML
  • Может быть очень медленным при неосторожном использовании (небольшие изменения могут иметь большие последствия)

Сторона клиента:

Advantages:
  • Удобный способ переложить обработку на клиентский код, где сценарии потенциально могут лучше знать, как лучше всего отформатировать полученный HTML.
Disadvantages:
  • Поддержка браузера повсюду.
  • Google не благодарит вас.

Чтобы смягчить недостатки на стороне клиента, вы можете обнаружить заголовки пользовательского агента на сервере и при необходимости переключиться на рендеринг на стороне сервера. Таким образом, если на ваш сайт попадет старый браузер, googlebot, msnbot и т. д., Вы сможете преобразовать их в html.

Michael Petito 25.02.2010 23:37

Не могли бы вы подробнее рассказать о том, "Google не будет вам благодарить"?

Jack 30.04.2017 18:26

@jackdh Я считаю, что он имеет в виду, что Google не будет отдавать предпочтение страницам, созданным с использованием XML / XSLT, в своем поисковом рейтинге. Просто потому, что Google не может правильно отображать эти страницы. stackoverflow.com/questions/7393522/…

Maziyar Mk 10.04.2018 13:13

XSLT на стороне клиента

  • Отключает прогрессивный рендеринг. Пользователь вообще ничего не увидит, пока не будет полностью загружена вся таблица стилей и данные.
  • Не поддерживается поисковыми системами и другими сканерами. Они увидят необработанный XML.
  • Не поддерживается старыми / менее продвинутыми браузерами.

XSLT в целом

  • Если вы тщательно не создадите таблицы стилей, их будет сложно поддерживать:
    • с многочисленными шаблонами может быть очень сложно определить, какие шаблоны применяются.
    • многословность синтаксиса XSLT и XML затрудняет понимание чего-либо с первого взгляда.
    • Уловки XPath заманчивы, но кошмар, чтобы изменить их позже.

Похоже на XML-фетиш "все поют-все-танцуют".

Поскольку с XSLT можно делать что угодно, с таким же успехом можно делать все. У меня были люди, которые спрашивали, почему хранилище данных - это не просто XSLT-преобразования между вводом, витриной данных и отчетами.

Преимущество. Все в XML.

Недостатки.

  • Не очень читабельно. Шаблоны ваших страниц связаны как преобразования XSLT с запутанными функциями циклов и условной обработки.

  • Любое изменение шаблонов страниц требует наличия эксперта по XSLT в дополнение к графическому дизайнеру, создавшему (и отлаживающему) HTML и CSS.

Самое большое преимущество: платформенный нейтральный способ рендеринга xml

Самый большой недостаток xsl сложно поддерживать

Однажды мне пришлось работать с xsl длиной более 4000 строк, который также включает несколько других шаблонов xsl. Теперь с этим было тяжело работать!

Я думаю, что XSLT великолепен, если построен правильно (мы используем структуру шаблонов в работе).

Приведенные выше ответы дают хороший обзор некоторых преимуществ и недостатков XSLT. Хочу добавить еще один минус. Мы обнаружили, что вы довольно быстро сталкиваетесь с проблемами масштабируемости при использовании XSLT для умеренно больших наборов данных.

При обработке файлов XML XSLT должен загружать в память весь документ. С Xalan это потребляет примерно в 10 раз больше размера входного файла (у saxon есть альтернативная реализация DOM, которая использует меньше памяти). Если какой-либо из ваших входных наборов данных превысит пару сотен мегабайт, ваш XSLT-процессор может просто выйти из строя.

Другие вопросы по теме