Я переписал свой встроенный JS в своем приложении rails на coffeescript... и я новичок в coffeescript...
Мой подход представляет собой смесь этих статей:
Мой код:
s = undefined
class App.PhotoLike
settings:
modalElement: $('#myModal')
likeButtonId: '#like'
photo_id: $('.image_info').attr('photo_id')
numberOfLikes: $('#likes_num')
constructor: (@el) ->
console.log('constructor called')
s = @settings
@bindUIActions()
return this
bindUIActions: ->
console.log('bindUIActions called')
$('#myModal').on 'click', '#like', -> likePhoto()
$(document).on "page:change", -> pageChange()
pageChange: ->
console.log('pageChange called')
photo = new App.Photo
likePhoto: ->
console.log('likePhoto called')
url = '/photos/' + s.photo_id + '/like'
$.get url, (data) ->
s.numberOfLikes.html data['likes'] + ' likes'
$(s.likeButtonId).toggleClass 'btn-success'
Это часть модели, которая загружается с помощью ajax, и после успешного выполнения этого вызова я создаю вышеуказанный класс (экземпляр):
new (App.PhotoLike)
Моя проблема. Модальный режим загружается, и все кажется хорошим. Но когда я запускаю событие:
$('#myModal').on 'click', '#like', -> likePhoto()
Я получил:
photo.like.self-942fcd8….js?body=1:25 Uncaught ReferenceError: likePhoto is not defined
поэтому он не знает функцию likePhoto. Я пробовал вызывать this.likePhoto и @likePhoto, но это относится к элементу кнопки, который запускает событие.
Итак, как мне это сделать? Другие подходы приветствуются. я не совсем уверен, что мне нужны классы... но я действительно хочу структурированный код...