AEM中的字符串操作?
我正在使用AEM6.0,在其中一个脚本中,我有两个变量 ${currentPage.path}-/content/geometricxx/en/tools ${pageHref}->/content/geometryxx/en/tools.htmlAEM中的字符串操作?,aem,sightly,Aem,Sightly,我正在使用AEM6.0,在其中一个脚本中,我有两个变量 ${currentPage.path}-/content/geometricxx/en/tools ${pageHref}->/content/geometryxx/en/tools.html 现在我需要比较这两者,但由于${currentPage.path}没有.html,它将失败。是否有任何方法可以将.html添加到它以成功比较它。否。没有直接的方法。下面摘自的文章告诉你原因 关注点分离:有意限制Sightly模板语言的表达能力,以确保
现在我需要比较这两者,但由于${currentPage.path}没有.html,它将失败。是否有任何方法可以将.html添加到它以成功比较它。否。没有直接的方法。下面摘自的文章告诉你原因 关注点分离:有意限制Sightly模板语言的表达能力,以确保使用真正的编程语言来表达相应的表示逻辑。这个可选逻辑是通过useapi模式从Sightly表达式调用的,这样就很容易理解给定视图的调用内容,并且对于同一资源的不同视图可能具有不同的逻辑 我建议使用Java/JavaScript或使用API来实现同样的效果 然而,如果你不可避免地需要在Sightly本身做这件事,那么你可以使用下面的肮脏的hack,尽管我不推荐它
<sly data-sly-test.pagePath = "${currentPage.path}.html"></sly>
<sly data-sly-test = "${pageHref == pagePath}">
<!--/** Your HTML here */-->
</sly>
类似的问题也出现了。没有。没有直接的方法。下面摘自的文章告诉你原因 关注点分离:有意限制Sightly模板语言的表达能力,以确保使用真正的编程语言来表达相应的表示逻辑。这个可选逻辑是通过useapi模式从Sightly表达式调用的,这样就很容易理解给定视图的调用内容,并且对于同一资源的不同视图可能具有不同的逻辑 我建议使用Java/JavaScript或使用API来实现同样的效果 然而,如果你不可避免地需要在Sightly本身做这件事,那么你可以使用下面的肮脏的hack,尽管我不推荐它
<sly data-sly-test.pagePath = "${currentPage.path}.html"></sly>
<sly data-sly-test = "${pageHref == pagePath}">
<!--/** Your HTML here */-->
</sly>
类似的问题也被提出了