cloudine与jcrop在chrome上工作但不是firefox或safari

时间:2014-04-16 18:02:13

标签: jquery ruby-on-rails firefox jcrop cloudinary

我有一个使用cloudinary,carrierwave和jcrop的rails 4 app。上传按钮和提交工作(使用javascript状态报告)在chrome上但不在firefox或safari上。在firefox控制台中,我得Empty string passed to getElementById().指向elem = document.getElementById( match[2] );注意,有时候在第二次或第三次尝试(点击提交并反复选择图像)之后,它有效。哦,请帮助我互联网世界你唯一的希望。

new.html.erb

<div id="dropzone">
<h1>Change Profile Photo.</h1>
<div class="container">
  <div class="row">
    <div class="col-xs-12 col-sm-10 col-sm-offset-1 col-md-8 col-md-offset-2">
      <div id="direct_upload">
        <p>Select the upload button or drag and drop an image.</p>
        <% if params[:dog_id] %>
          <% url = master_dog_profile_pics_path %>
        <% else %>
          <% url = master_profile_pics_path %>
        <% end %>
          <%= form_for(@photo, :url => url, role: "form") do |f| %>          
          <div class="form_line form-group">
            <%= f.label :image, "Image:" %><br />
            <div class="upload_button_holder">
              <%= link_to "Upload", "#", class: "btn btn-primary upload_button form-control" %>
              <%= f.cl_image_upload :image, class: "form-control" %>
            </div>
            <span class="status"></span>
          </div>

          <div class="form-group">
            <div class="form_control">
              <div class="preview"></div>
            </div>
          </div>

            <%= f.hidden_field :crop_x %>
            <%= f.hidden_field :crop_y %>
            <%= f.hidden_field :crop_w %>
            <%= f.hidden_field :crop_h %>

          <div class="form-group">
            <div class="">
              <%= f.submit "Submit Photo", class: "btn btn-lg btn-success" %>
              <% if @error %><span class="error"><%= @error %></span><% end %>
            </div>
          </div>
          <%= f.hidden_field :bytes %>
          <%= hidden_field_tag :direct, params[:direct] %>
        <% end %>
      </div>

      <% if params[:photo_option] == "dog_photo" %>
      <% link_to "Back to House", master_path(@master) %>
      <% else %>
        <a href="<%= edit_master_registration_path %>">Back to Master edit.</a>
      <% end %>
    </div>
  </div>
</div>
</div>

<!-- Configure Cloudinary jQuery plugin -->
<%= cloudinary_js_config %>

profile_pics.js.coffee

update = (c) ->
  $('#profile_pic_crop_x').val(c.x)
  $('#profile_pic_crop_y').val(c.y)
  $('#profile_pic_crop_w').val(c.w)
  $('#profile_pic_crop_h').val(c.h)
$(document).ready ->
  $(".cloudinary-fileupload").fileupload(
    dropZone: "#dropzone"
    start: (e) ->
      $(".status").text "Starting upload..."

    progress: (e, data) ->
      $(".status").text "Uploading... " + Math.round((data.loaded * 100.0) / data.total) + "%"

    fail: (e, data) ->
      $(".status").text "Upload failed"
  ).off("cloudinarydone").on "cloudinarydone", (e, data) ->
    $("#photo_bytes").val data.result.bytes
    $(".status").text ""
    $(".preview").html($.cloudinary.image(data.result.public_id,
      format: data.result.format
      width: 400
      height: 400
      crop: "limit"
      id: "jcrop_target"
    )).css height = "400"
    $("#jcrop_target").Jcrop
      aspectRatio: 1
      setSelect: [100, 0, 200, 200]
      onSelect: update
      onChange: update
    $(".previewpost").html($.cloudinary.image(data.result.public_id,
      format: data.result.format
      width: 400
      height: 400
      crop: "limit"
      class: "img-responsive"
    )).css height = "400"

的application.js

//= require jquery
//= require jquery_ujs
//= require jquery.ui.all
//= require bootstrap
//= require turbolinks
//= require cloudinary
//= require jquery.Jcrop
// require cloudinary/processing // Optional - client side processing (resizing and validation)
//= require autocomplete-rails
//= require_tree .

的Gemfile

...
gem "jquery-rails"
gem 'jquery-ui-rails'
gem "jcrop-rails-v2", "~> 0.9.12.3"
...

1 个答案:

答案 0 :(得分:0)

这是turbolinks的一个问题。我添加了jquery.turbolinks gem并在javascript的开头放入document.ready。