undefined method `render’ for module in rails

huangapple go评论63阅读模式
英文:

undefined method `render' for module in rails

问题

  1. module UserCheck
  2. def self.status(onboarding, params)
  3. if onboarding && params[:process].present?
  4. render json: { status: :ok }
  5. else
  6. render json: { error: 'You have already finished your onboarding.' }, status: :not_implemented
  7. end
  8. end
  9. end
  10. module MyAccount::User
  11. class UserController < MyAccountController
  12. def update
  13. UserCheck.status(wizard_onboarding, params)
  14. end
  15. end
  16. end

users_controller中,我使用UserCheck模块来检查入职状态,并在else情况下返回错误。但是当else条件运行时,它不会呈现JSON错误消息,而是返回undefined method 'render' for UserCheck:Module。你可以帮我解决这个问题吗?

英文:
  1. module UserCheck
  2. def self.status(onboarding, params)
  3. if onboarding &amp;&amp; params[:process].present?
  4. render json: { status: :ok }
  5. else
  6. render json: { error: &#39;You have already finished your onboarding.&#39; }, status: :not_implemented
  7. end
  8. end
  9. end
  10. module MyAccount::User
  11. class UserController &lt; MyAccountController
  12. def update
  13. UserCheck.status(wizard_onboarding, params)
  14. end
  15. end
  16. end

In the users_controller, I am using the module UserCheck to check the onboarding status and return an error in the else case. But when the else condition runs it doesn’t render json error message but instead returns the undefined method &#39;render&#39; for UserCheck:Module. Could you help me fix this issue?

答案1

得分: 2

以下是您要翻译的内容:

  1. 我会将控制权传递给该方法,然后在该控制器上调用 render,就像这样:
  2. module UserCheck
  3. def self.status(onboarding, params, controller)
  4. if onboarding && params[:process].present?
  5. controller.render json: { status: :ok }
  6. else
  7. controller.render json: { error: '您已完成您的入职流程。' }, status: :not_implemented
  8. end
  9. end
  10. end
  11. module MyAccount::User
  12. class UserController < MyAccountController
  13. def update
  14. UserCheck.status(wizard_onboarding, params, self)
  15. end
  16. end
  17. end
  18. 就个人而言,我认为将如此简单的代码从控制器中提取到模块中没有任何好处。这使得控制器更难理解和调试。要理解控制器返回了什么,您需要查看不同的文件。
英文:

I would pass the controller to that method and call then render on that controller, like this:

  1. module UserCheck
  2. def self.status(onboarding, params, controller)
  3. if onboarding &amp;&amp; params[:process].present?
  4. controller.render json: { status: :ok }
  5. else
  6. controller.render json: { error: &#39;You have already finished your onboarding.&#39; }, status: :not_implemented
  7. end
  8. end
  9. end
  10. module MyAccount::User
  11. class UserController &lt; MyAccountController
  12. def update
  13. UserCheck.status(wizard_onboarding, params, self)
  14. end
  15. end
  16. end

Personally, I see no benefit in extracting such simple code from the controller into a module. It makes the controller much harder to understand and to debug. And to understand what the controller is returning, you need to look into a different file.

huangapple
  • 本文由 发表于 2023年2月14日 02:06:19
  • 转载请务必保留本文链接:https://go.coder-hub.com/75439664.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定