Cloudinary cl_image_upload vs cl_image_upload_tag

时间:2014-07-08 02:23:22

标签: javascript ruby-on-rails-4 carrierwave cloudinary

我正在尝试启用从浏览器到cloudinary的直接图片上传。我遇到的问题是,根据以下语法,图像未上传。

<%= form_for(@product_image) do |f| %>
  <div class="field">
    <%= f.cl_image_upload(:image) %>
  </div>
  <%= f.submit %>
<% end %>

如果我替换此块

<%= f.cl_image_upload(:image) %>

<%= cl_image_upload_tag("product_image[image]") %>

上传仍然没有发生。但是,如果我将它们放在一起,那么两者都会上传。

我比较了2个cloudinary辅助方法生成的html,它们生成了完全相同的html代码。看看这两个辅助方法的代码,似乎有人正在调用另一个。

def cl_image_upload(object_name, method, options={})
  cl_image_upload_tag("#{object_name}[#{method}]", options)
end

def cl_image_upload_tag(field, options={})
  html_options = options.delete(:html) || {}
  if options.delete(:multiple)
    html_options[:multiple] = true
    field = "#{ field }[]" unless field.to_s[-2..-1] == "[]"
  end

  tag_options = html_options.merge(:type=>"file", :name=>"file",
    :"data-url"=>cl_upload_url(options),
    :"data-form-data"=>cl_upload_tag_params(options),
    :"data-cloudinary-field"=>field,
    :"class" => [html_options[:class], "cloudinary-fileupload"].flatten.compact
  ).reject{|k,v| v.blank?}
  content_tag("input", nil, tag_options)
end

如果我真的只想使用一个块&lt;%= f.cl_image_upload(:image)%&gt;,那么我还需要添加额外的javascript

$(&#39; .cloudinary-文件上传).cloudinary_fileupload();

在您看来,使用Carrierwave直接从浏览器上传到Cloudinary的最佳方法是什么?

1 个答案:

答案 0 :(得分:0)

Cloudinary有一个完整的示例项目,其中包括使用jQuery库的客户端上传,包括CarrierWave集成。你可以看看并尝试一下: https://github.com/cloudinary/cloudinary_gem/tree/master/samples/photo_album