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>
我正在尝试重新计算并在 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>