Вопрос

Я пытаюсь включить приведенный ниже код JavaScript Оптимизатора веб-сайтов Google в шаблон страницы Zope3.Он используется для A/B-тестирования.

Однако анализатор HTML шаблона, который, как я полагаю, является стандартным модулем Python HTMLParser, выдает следующую ошибку:

raise PTRuntimeError(str(self._v_errors))
- Warning: Compilation failed
- Warning: <class 'HTMLParser.HTMLParseError'>: bad end tag: u"</sc'+'ript>", at line 45, column 44
PTRuntimeError: ['Compilation failed', '<class \'HTMLParser.HTMLParseError\'>: bad end tag: u"</sc\'+\'ript>", at line 45, column 44']

Насколько я понимаю, у меня есть два варианта:

  • Перепишите код, чтобы он прошел (мой JS-foo слаб, не знаю, с чего начать).

  • Заставьте HTMLParser игнорировать код.Я пробовал теги CDATA, но безуспешно.Я также пробовал поместить js во внешний файл и связать с ним ссылку, но это кажется нарушить функциональность оптимизатора.

Подозреваемый код:

<!-- Google Website Optimizer Control Script -->
<script>
<![CDATA[
function utmx_section(){}function utmx(){}
(function(){var k='1010538027',d=document,l=d.location,c=d.cookie;function f(n){
if(c){var i=c.indexOf(n+'=');if(i>-1){var j=c.indexOf(';',i);return c.substring(i+n.
length+1,j<0?c.length:j)}}}var x=f('__utmx'),xx=f('__utmxx'),h=l.hash;
d.write('<sc'+'ript src="'+
'http'+(l.protocol=='https:'?'s://ssl':'://www')+'.google-analytics.com'
+'/siteopt.js?v=1&utmxkey='+k+'&utmx='+(x?x:'')+'&utmxx='+(xx?xx:'')+'&utmxtime='
+new Date().valueOf()+(h?'&utmxhash='+escape(h.substr(1)):'')+
'" type="text/javascript" charset="utf-8"></sc'+'ript>')})();
]]>
</script><script>utmx("url",'A/B');</script>
<!-- End of Google Website Optimizer Control Script -->
Это было полезно?

Решение

Учитывая слабость парсера, вы можете попытаться разбить части CDATA, которые он пытается интерпретировать как теги, например.где у тебя сейчас есть </sc'+'ript>' пытаться <'+'/sc'+'ript>' и т. д (+ выполняет объединение строк в JS, как и в Python, поэтому он снова соединяет теги, которые вы разбиваете таким образом, точно так же, как теги, которые уже разбиты в оригинале).

Если это продолжает выдавать ошибки анализа, потеряйте CDATA и измените каждый < в &lt;, каждый > в &gt; -- не уверен, что JS справится с этим, но попробовать стоит...удачи!

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

На самом деле, эту проблему легко решить, полностью отказавшись от парсера HTML.Просто поместите сценарий управления Google в отдельный файл или объект в виде Javascript и перетащите его на страницу с включением TAL.

Анализатор HTML не используется, если файл импортируется как Javascript.

Я предполагаю, что парсеру не нравится тот факт, что

</sc'+'ript> 

делится на две части.Какой JavaScript является совершенно допустимым, но может сбить с толку htmlparser?

Возможно, захочу попробовать

<'+'/sc'+'ript>'

Еще один вариант — поместить код во внешний файл и ссылаться на него вместо встраивания его непосредственно в код.Я сделал это, и это работает хорошо.Это всегда более простой способ, если вы не хотите, чтобы валидатор сканировал JavaScript или CSS.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top