如何为带有装饰器的React.js组件编写一个通用的快捷方法
How to generically write a shortcut method for React.js components with decorators?
我使用React Intl进行内化,并且必须编写this.props.intl.formatMessage({id: 'some.message.id'}, values)
以在render()方法中获得翻译的字符串。现在,一个装饰器应该如何提供一个快捷功能,这样我就可以像_t('some.message.id', values)
或类似的?
我知道我可以写另一个类来扩展React。组件或将组件包装在另一个类或其他任何东西中,但如果可能的话,我想用装饰器来做(为了学习和理解目的)。
这里有一些东西可以让你开始:
function mydecorator(target, key, descriptor) {
const method = descriptor.value;
descriptor.value = function(...args) {
args.push(this.props.intl.formatMessage); // may need `.bind(...)`
return method.apply(this, args);
}
}
使用:@mydecorator
render(_t) {
...
}
装饰器将render
替换为一个函数,该函数将对this.props.intl.formatMessage
的引用推入随后在对原始render
的调用中传递的参数列表(这,AFAIK,不接受参数,因此您可能可以通过取出args
变量来缩短代码)。
你当然可以push一个中间函数作为参数,这样可以更好地处理id
参数,等等
相关文章:
- 将一个方法转换为promise:Nodejs
- 如何在所有ng点击事件AngularJS上启动一个方法
- 创建一个方法,通过一个窗口进行迭代并获取Titanium中的所有控件
- 如何创建一个方法来验证数组的范围
- 如何将一个方法延迟到另一个方法首先完成,javascript
- 在Javascript中对类的每个实例调用一个方法
- 如何重写一个方法,并且仍然能够在重写的方法中使用基方法
- NodeJS-从同一文件中的另一个方法调用一个方法
- 有没有任何情况下,一个方法不应该是原型方法
- Jasmine间谍的函数称为一个方法
- 在带有参数列表的表单submit上调用一个方法
- 方法不在另一个方法内部调用
- 在 1 个方法中增加变量值会触发另一个方法的 for 循环,欢迎任何建议
- 如何使用javascript express node将变量从控制器中的一个方法公开.js到另一个控制器.js
- 如何在javascript中将变量的值分配给另一个方法
- 在浏览器关闭时,单击确认对话框中的“停留在页面上”,执行一个方法
- 使用一个方法在c#中启动其他方法
- 如何在Ember中转换到另一个路由时调用一个方法
- 在typescript中重载一个方法
- 我可以在setInterval函数中放入一个方法作为参数吗