12

我正在尝试实现一些我希望相对简单的东西......我有一个组件(让我们称之为包装器组件),它通过 data-sly-resource 标签在其中包含另一个组件(让我们称之为内部组件) :

<div data-sly-resource="${ 'inner' @ resourceType='/projectname/components/inner' }"></div>

我想用这个标签传入一些额外的参数,特别是可以在内部组件模板中通过视觉拾取的参数?我正在尝试根据通过 data-sly-resource 调用组件时传入的参数来指定是否打开内部模板外部 html 标记。

在尝试并仔细阅读了漂亮的文档之后,我找不到实现这一目标的方法。

有谁知道这是否可能?

非常感谢,

戴夫

4

4 回答 4

9

如果此处提出的替代方案不适合您,您可以使用 Use-API 来写入和读取请求属性。

两个组件的快速示例,其中外部组件设置属性,然后由内部组件显示:

/apps/siteName/components/
    outer/ [cq:Component]
        outer.html
    inner/ [cq:Component]
        inner.html
    utils/ [nt:folder]
        setAttributes.js
        getAttributes.js
/content/outer/ [sling:resourceType=siteName/components/outer]
    inner [sling:resourceType=siteName/components/inner]

/apps/siteName/components/outer/outer.html:

<h1>Outer</h1>
<div data-sly-use="${'../utils/setAttributes.js' @ foo = 1, bar = 2}"
     data-sly-resource="inner"></div>

/apps/siteName/components/inner/inner.html:

<h1>Inner</h1>
<dl data-sly-use.attrs="${'../utils/getAttributes.js' @ names = ['foo', 'bar']}"
    data-sly-list="${attrs}">
    <dt>${item}</dt> <dd>${attrs[item]}</dd>
</dl>

/apps/siteName/components/utils/setAttributes.js:

use(function () {
    var i;
    for (i in this) {
        request.setAttribute(i, this[i]);
    }
});

/apps/siteName/components/utils/getAttributes.js:

use(function () {
    var o = {}, i, l, name;
    for (i = 0, l = this.names.length; i < l; i += 1) {
        name = this.names[i];
        o[name] = request.getAttribute(name);
    }
    return o;
});

访问 /content/outer.html 时的结果输出:

<h1>Outer</h1>
<div>
    <h1>Inner</h1>
    <dl>
        <dt>bar</dt> <dd>2</dd>
        <dt>foo</dt> <dd>1</dd>
    </dl>
</div>

正如@AlasdairMcLeay 所评论的那样,如果请求中多次包含内部组件,这个提议的解决方案会出现问题:组件的后续实例仍然会看到最初设置的属性。

这可以通过在访问属性时删除属性来解决(在 getAttributes.js 中)。但是,如果内部组件被拆分为多个都需要访问这些属性的 Sightly(或 JSP)文件,这将再次成为问题,因为访问请求属性的第一个文件也会删除它们。

这可以通过一个标志来进一步解决,该标志告诉在访问它们时是否应该删除属性......但它也说明了为什么使用请求属性不是一个好的模式,因为它基本上包括使用全局变量作为一种方式组件之间进行通信。因此,如果此处提出的其他两个解决方案不是一个选项,请将此视为一种解决方法。

于 2015-01-27T18:12:12.377 回答
5

有一个更新的功能,可以在 data-sly-include 和 data-sly-resource 上设置请求属性:

<sly data-sly-include="${ 'something.html' @ requestAttributes=amapofattributes}" />

不幸的是,似乎不可能用 HTL(=Sightly)表达式构造 Map,而且我看不到从 HTL 读取请求属性的方法,因此您仍然需要一些 Java/Js 代码。

于 2017-09-25T13:40:17.067 回答
0

抱歉不行。没有办法扩展美观的功能。您不能添加新的 data-sly 属性或修改现有属性。您能做的最好的事情就是使用USE API编写自己的帮助程序

于 2014-09-02T13:22:25.313 回答
0

如果您只是需要在不同情况下从内部组件中包装或解包 html,那么您可以只保留组件中的 html 未包装,并仅在需要时使用以下语法包装它:

<div data-sly-resource="${ 'inner' @ resourceType='/projectname/components/inner', decorationTagName='div', cssClassName='someClassName'}"></div>

如果您需要更复杂的逻辑,并且需要将值传递给内部组件模板,则可以使用选择器。使用选择器包含资源的语法是:

<div data-sly-resource="${ 'inner' @ resourceType='/projectname/components/inner', selectors='mySelectorName'}"></div>

检查内部组件中的选择器的语法是:

${'mySelectorName' in request.requestPathInfo.selectorString}"

或者

${'mySelectorName' == request.requestPathInfo.selectorString}"
于 2020-04-15T18:18:15.680 回答