Polymer 1.0:Refresh/Re-Render 没有 属性 绑定的计算值

Polymer 1.0: Refresh/Re-Render Computed Value Without Property Binding

我正在尝试重新计算并在 Polymer 1.0 模板中呈现一个值。但是,我尝试在不绑定任何属性的情况下执行此操作。

万一重要,用例是用于使用字符串键查找翻译值的翻译机制。当'translations'值发生变化时,需要重新计算translate()调用。

组件定义如下:

<dom-module id="my-component">
    <template>
        <style></style>
        <p><span>[[translate("SOME_STRING")]]</span></p>
    </template>

    <script>
        var MyComponent = Polymer({
            is: "my-component",
            properties: {
                translations: {
                    type: Object,
                    notify: true,
                    value: {
                        "SOME_STRING": "Some String"
                    }
                }
            },
            translate: function (key) {
                if (this.translations.hasOwnProperty(key)) {
                    return this.translations[key];
                }
            }
        });
    </script>
</dom-module>

我可以通过将 translations 属性 添加到 translate() 调用来使刷新工作,如下所示:

<p><span>[[translate("SOME_STRING", translations)]]</span></p>

但是,我想做的是 re-compute/refresh 而不必在每次调用中将 translations 属性 作为第二个参数(也有其他原因)。

基本上,当 translations 对象更新为不同的语言环境翻译时,我希望重新计算 translate("SOME_STRING")

这可能吗?有没有办法重新渲染模板,甚至只是手动重新渲染整个组件?如何?如果不是,在绑定中没有 属性 的情况下重新呈现计算值或模板的最简单方法是什么?

怎么样????

<dom-module id="my-component">
<template>
    <style></style>
    <p><span>[[str]]</span></p>
</template>

<script>
    var MyComponent = Polymer({
        is: "my-component",
        properties: {
            translations: {
                type: Object,
                notify: true,
                value: {
                    "SOME_STRING": "Some String"
                },
                observer: '_Changed'
            },
            str: {
                type: String,
                value: "hello"
              }

        },
        _Changed: function(){
           this.set("str",this.translate(this.str));
        },
        translate: function (key) {
            if (this.translations.hasOwnProperty(key)) {
                return this.translations[key];
            }
        }
    });
</script>