我对能够使用 @myDecorator 语法(使用 babel)感到非常兴奋。我正在尝试装饰生命周期函数之一,特别是 componentWillMount,并检查装饰器中组件的 props 和 context。但是,我似乎无法访问 props 或 context。我不确定这是否是一种反模式,或者我只是在做这个错误。
小例子:
// TestComponent.jsx
import checkProps from 'checkProps.js';
class TestComponent extends React.Component {
@checkProps
componentWillMount() {
// Do something.
}
render() {
return <div>My Component</div>
}
}
和
// checkProps.js
export function checkProps(target) {
console.log(target.props);
}
我也尝试过装饰器的箭头函数并检查 this,但我认为装饰器不会以这种方式组合东西。
我也尝试过让我的装饰器成为工厂并传入 this.props 和 this.context 但是 this 在装饰 a 时未定义组件生命周期函数。
最佳答案
ES7 ECMAScript 装饰器有 the same API as Object.defineProperty(target, name, descriptor)所以 target 参数是应用装饰器时的类,而不是 React 调用它时的类。要影响装饰器在运行时所做的事情,您必须修改 descriptor.value,即被装饰的实际函数:
export function checkProps(target, name, descriptor) {
// Save the original method, it'd be a good idea
// to check that it really is a function
const decoratee = descriptor.value;
// Modify the descriptor to return our decorator
// function instead of the original
descriptor.value = function decorated(...args) {
// Do something before ...
console.log('before: ' + name, this.props, args);
// Calling the decorated method on this object
// with some arguments that could have been
// augmented by this decorator
decoratee.apply(this, args);
// Do something after ...
console.log('after: ' + name);
};
}
// Or if you wanted to use a factory function to supply some configuration
// to the decorator you can do it this way
export function checkProps(config) {
return function configurableCheckProps(target, name, descriptor) {
// Save the original method, it'd be a good idea
// to check that it really is a function
const decoratee = descriptor.value;
if (config.someOption) {
// Do something based on the config
}
// Modify the descriptor to return our decorator
// function instead of the original
descriptor.value = function decorated(...args) {
// Do something before ...
console.log('before: ' + name, this.props, args);
if (config.someOption) {
// Do something based on the config
}
// Calling the decorated method on this object
// with some arguments that could have been
// augmented by this decorator
decoratee.apply(this, args);
// Do something after ...
console.log('after: ' + name);
};
};
}
这是 an example that also modifies the behavior of a method这更彻底地证明了这一点。
希望这对您有所帮助。编码愉快!
编辑:正如评论者所指出的,装饰器不是 ES7 的一部分,但截至 2016 年 3 月the proposal is still in Stage 1 , 我的坏
EDIT2:截至 2018 年 6 月,提案在 the proposal is still in Stage 2 中, 我们越来越近了
关于javascript - 带有 React 组件的装饰器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36286384/
使用rspec-rails3.0+,测试设置分为spec_helper和rails_helper我注意到生成的spec_helper不需要'rspec/rails'。这会导致zeus崩溃:spec_helper.rb:5:in`':undefinedmethod`configure'forRSpec:Module(NoMethodError)对thisissue最常见的回应是需要'rspec/rails'。但这是否会破坏仅使用spec_helper拆分rails规范和PORO规范的全部目的?或者这无关紧要,因为Zeus无论如何都会预加载Rails?我应该在我的spec_helper中做
假设我有一个类A,里面有一些方法。假设stringmethodName是这些方法之一,我已经知道我想给它什么参数。它们在散列中{'param1'=>value1,'param2'=>value2}所以我有:params={'param1'=>value1,'param2'=>value2}a=A.new()a.send(methodName,value1,value2)#callmethodnamewithbothparams我希望能够通过传递我的哈希以某种方式调用该方法。这可能吗? 最佳答案 确保methodName是一个符号,而
当我进入Rails控制台时,我已将pry设置为加载代替irb。我找不到该页面或不记得如何将其恢复为默认行为,因为它似乎干扰了我的Rubymine调试器。有什么建议吗? 最佳答案 我刚发现问题,pry-railsgem。忘记了它的目的是让“railsconsole”打开pry。 关于ruby-on-rails-带有Pry的Rails控制台,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/question
我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的
我了解instance_eval和class_eval之间的基本区别。我在玩弄时发现的是一些涉及attr_accessor的奇怪东西。这是一个例子:A=Class.newA.class_eval{attr_accessor:x}a=A.newa.x="x"a.x=>"x"#...expectedA.instance_eval{attr_accessor:y}A.y="y"=>NoMethodError:undefinedmethod`y='forA:Classa.y="y"=>"y"#WHATTT?这是怎么回事:instance_eval没有访问我们的A类(对象)然后它实际上将它添加到
我在一个简单的RailsAPI中有以下Controller代码:classApi::V1::AccountsControllerehead:not_foundendendend问题在于,生成的json具有以下格式:{id:2,name:'Simpleaccount',cash_flows:[{id:1,amount:34.3,description:'simpledescription'},{id:2,amount:1.12,description:'otherdescription'}]}我需要我生成的json是camelCase('cashFlows'而不是'cash_flows'
我有一个将某些事件写入队列的Rails3应用。现在我想在服务器上创建一个服务,每x秒轮询一次队列,并按计划执行其他任务。除了创建ruby脚本并通过cron作业运行它之外,还有其他稳定的替代方案吗? 最佳答案 尽管启动基于Rails的持久任务是一种选择,但您可能希望查看更有序的系统,例如delayed_job或Starling管理您的工作量。我建议不要在cron中运行某些东西,因为启动整个Rails堆栈的开销可能很大。每隔几秒运行一次它是不切实际的,因为Rails上的启动时间通常为5-15秒,具体取决于您的硬件。不过,每天这样做几
在Ruby(或Rails)中,我们可以做到new_params=params.merge({:order=>'asc'})现在new_params是一个带有添加键:order的散列。但是是否有一行可以返回带有已删除key的散列?线路new_params=params.delete(:order)不会工作,因为delete方法返回值,仅此而已。我们必须分3步完成吗?tmp_params=paramstmp_params.delete(:order)returntmp_params有没有更好的方法?因为我想做一个new_params=(params[:order].blank?||para
我有这个:AccountSummary我想单击该链接,但在使用link_to时出现错误。我试过:bot.click(page.link_with(:href=>/menu_home/))bot.click(page.link_with(:class=>'top_level_active'))bot.click(page.link_with(:href=>/AccountSummary/))我得到的错误是:NoMethodError:nil:NilClass的未定义方法“[]” 最佳答案 那是一个javascript链接。Mechan
如何使用rubyonrails获取网络上某处其他网站的页面数据? 最佳答案 您可以使用httparty只是获取数据示例代码(来自example):requireFile.join(dir,'httparty')require'pp'classGoogleincludeHTTPartyformat:htmlend#google.comredirectstowww.google.comsothisislivetestforredirectionppGoogle.get('http://google.com')puts'','*'*7