4

我只是想为我们的客户创建一个 API 来与我们的主要 Rails 3 应用程序进行交互。

一方面,我希望 json 响应包含一些表单。基本上是我们控制并出现在他们网站上的一些表单代码。

我有这个工作正常(简化):

def login_form
  @response = Form.find_by_something(params[:something_else])
  if @response 
    render :status=>200, :json=>{:response => @response} 
  end
end

在客户端,我可以获取:

@logins = HTTParty.get("#{set_auth_url}/api/v1/logins.json?auth_token=xyz&something_else=abc").parsed_response

并显示表格

= @logins["response"].html_safe

问题是,表单代码有一些动态变量:

例如:

<div class="login">
  <FORM name="form1" METHOD="get" action="<%= request.path %>?">
  <INPUT TYPE="HIDDEN" NAME="chal" VALUE="<%= params['challenge'] %>">
  <% if @current_location['success_url'] %>
    <INPUT TYPE="HIDDEN" NAME="userurl" VALUE="/success">
  <% end %>
  <input type="hidden" name="UserName" placeholder="Username" value="<%= @user['username']['username'] %>">
  <input type="submit" name="login" value="Login" class="btn">
</div>

我想知道这是否是个好主意?如果是这样,我怎样才能在 html 中打破这些变量?

如果不是,有人可以推荐一个更好的方法来解决它。

4

2 回答 2

1

在准备响应时,这些变量在服务器端是否已知?在这种情况下,我会尝试通过模板引擎运行它们:json=> { :response => ERB.new(@response).result(binding) }- 客户端只会收到适用于他的案例的 html。

于 2012-10-10T21:43:36.593 回答
1

为什么不为此使用 Javascript 模板,如 Jquery 模板或 Mustache 或 Handlebar

所以像这样将表单保留在客户端

我将在这里使用 Mustache 来描述它....

...

    <script id="template" type="text/template">
      <div class="login">
      <FORM name="form1" METHOD="get" action={{request_path}}>
      <INPUT TYPE="HIDDEN" NAME="chal" VALUE={{challenges}}>
      {{boolean_value}} 
      <INPUT TYPE="HIDDEN" NAME="userurl" VALUE="/success">
      {{/boolean_value}}
      <input type="hidden" name="UserName" placeholder="Username" value={{user_name}}>
      <input type="submit" name="login" value="Login" class="btn">
     </div>
    </script>

</html>

下一部分是以 ajax 的形式获取响应

使用任何 Javascript 框架我想它可以实现我在这里使用 jQuery

<script type="text/javascript">
  $(document).ready(function() {
    $.ajax({
      // make ajax call over here
      success: function(data)  {
        // JSON DATA 
         var template = $('script#template').html();
         $([container where html is place]).html(Mustache.to_html(template,data));
      }

    })
 })

希望这个帮助

不知道您希望如何使用普通的 Form html 标签而不是 form_tag,因为它不包含真实性令牌

希望这有帮助

于 2012-10-17T13:06:28.173 回答