【发布时间】:2023-03-22 01:19:01
【问题描述】:
我正在使用骨干网和 rails 'paperclip' gem 实现异步照片上传:
问题:
- 我需要使用 jQuery 上传(或等效库)吗?
- 如果是这样,我是否只需覆盖 photocollection.sync 来调用库?
项目.rb
class Item < ActiveRecord::Base
has_many: photos
...
照片.rb
class Photo < ActiveRecord::Base
attr_accessible :photo
belongs_to :item
has_attached_file :photo
...
ItemView.js.coffee
class MySite.Views.Items.Edit extends Backbone.View
template: JST['items/edit']
initialize: ->
@modelBinder = new Backbone.ModelBinder
@model.on('change', @render(), this)
events: ->
'submit #edit_item_form' : 'save_item'
render: ->
$(@el).html @template( item: @model )
@new_photo = @model.new_photo()
@modelBinder.bind @model, $("#item_fields")
@modelBinder.bind @new_photo, $("#photo_fields")
@
save_item: (e) ->
e.preventDefault()
@model.save()
@new_photo.save()
Edit.jst.eco
<form id="edit_item_form" accept-charset="UTF-8" data-remote="true" enctype="multipart/form-data">
<div id="item_fields"> .... </div>
<div id="photo_fields">
<input type="file" id="upload_photo" name="photo[photo]" />
</div>
...
欢迎提出整体设计改进建议
【问题讨论】:
标签: ruby-on-rails backbone.js coffeescript paperclip ajax-upload