css动态代码的定界符

html-css022

css动态代码的定界符,第1张

当输入url地址后网页出现:Fatal error: Uncaught exception 'SmartyCompilerException'

with message 'Syntax Error in template

"E:\wamp\www\cms\system/templates/index.html" on line 79

"$("#job").load("./system/templates/touch/test.php",{catid:3})" -

Unexpected ":", expected one of: "}" , " "' in

E:\wamp\www\cms\system\Smarty\sysplugins\smarty_internal_templatecompilerbase.php

on line 441这样的问题,通常是css和js的{}与smarty定界符冲突导致的。

解决办法有两个:

1.可以把 smarty 的定界符设成 <{ }>

复制代码 代码如下:

$tpl->left_delimiter = '<{'

$tpl->right_delimiter = '}>'

2.对于js的{}与smarty定界符冲突,可以用smarty的literal处理,可以把JS代码包含在{literal}{/literal}之间就可以了。

复制代码 代码如下:

<{literal}>

$ (

<span style="white-space:pre"></span>function () { alert ('培训课程')}

)

<{/literal}>

可以把 smarty 的定界符设成 <{ }>

[html] view plain copy

$tpl->left_delimiter = '<{'

$tpl->right_delimiter = '}>'

2.可以用smarty的literal处理,可以把JS代码包含在{literal}{/literal}之间就可以了。

[html] view plain copy

{literal}

$ (

function () { alert ('培训课程')}

)

{/literal}

和在html中用法一样,可能是要用smarty语法把CSS文件包含进去,如果你直接写在网页里面可能是不行,还有就是要注意路径的问题,因为smarty 是模板和动态文件分开的,你要注意一下路径,是不是正确