Переменные шаблона dwoo внутри JavaScript?
У меня есть этот код.
{if $loginUrl}
{literal}
<script type="text/javascript">
var newwindow;
var intId;
function login() {
var screenX = typeof window.screenX != 'undefined' ? window.screenX : window.screenLeft,
screenY = typeof window.screenY != 'undefined' ? window.screenY : window.screenTop,
outerWidth = typeof window.outerWidth != 'undefined' ? window.outerWidth : document.body.clientWidth,
outerHeight = typeof window.outerHeight != 'undefined' ? window.outerHeight : (document.body.clientHeight - 22),
width = 500,
height = 270,
left = parseInt(screenX + ((outerWidth - width) / 2), 10),
top = parseInt(screenY + ((outerHeight - height) / 2.5), 10),
features = (
'width=' + width +
',height=' + height +
',left=' + left +
',top=' + top
);
newwindow=window.open('{$loginUrl}','Login by facebook',features);
if (window.focus) {newwindow.focus()}
return false;
}
</script>
{/literal}
{/if}
Это шаблоны dwoo, мне интересно, как я могу использовать мои переменные dwoo внутри javascript? Я пытаюсь сделать это только на вы можете увидеть в коде, но это не работает. Мне нужно деформировать код между {literal}, чтобы он мог работать.
3 ответа
Удалите теги {literal}. Dwoo достаточно умен, чтобы избежать путаницы в вашем JavaScript, если вы не используете объектные литералы в одной строке.
Если быть точным, {после пробела, табуляции или разрыва строки не будет проанализирован Dwoo. Единственная проблема, если вы делаете что-то вроде:
{foo: "bar"}
В этом случае у вас есть несколько способов предотвратить синтаксический анализ Dwoo:
\{foo: "bar"} // escape the {
{ foo: "bar"} // add a space so it doesn't match it
{literal}{foo: "bar"}{/literal} // wrap with literal, but then you can't use vars inside again
// or expand it to use multiple lines, which is usually more readable anyway
{
foo: "bar"
}
Вы можете просто сделать {/literal}{$the_varible}{literal}
вставлять переменные внутри литеральных тегов.
Хм.. нашел "исправление", но оно жестко закодировано и должно быть что-то лучше:
{if $loginUrl}
{literal}
<script type="text/javascript">
var newwindow;
var intId;
function login() {
var screenX = typeof window.screenX != 'undefined' ? window.screenX : window.screenLeft,
screenY = typeof window.screenY != 'undefined' ? window.screenY : window.screenTop,
outerWidth = typeof window.outerWidth != 'undefined' ? window.outerWidth : document.body.clientWidth,
outerHeight = typeof window.outerHeight != 'undefined' ? window.outerHeight : (document.body.clientHeight - 22),
width = 500,
height = 270,
left = parseInt(screenX + ((outerWidth - width) / 2), 10),
top = parseInt(screenY + ((outerHeight - height) / 2.5), 10),
features = (
'width=' + width +
',height=' + height +
',left=' + left +
',top=' + top
);
newwindow=window.open({/literal}'{$loginUrl}'{literal},'Login by facebook',features);
if (window.focus) {newwindow.focus()}
return false;
}
</script>
{/literal}
{/if}
Просто.. некрасиво.