title | category | layout | prism_languages | intro | |
---|---|---|---|---|---|
Modella |
JavaScript libraries |
2017/sheet |
|
[Modella](https://www.npmjs.com/package/modella) allows you to create simple models in JavaScript. This is a guide on basic usage of Modella in CoffeeScript.
|
User = Modella('User')
.attr('name')
.attr('email', { required: true })
.use(require('modella-validators'))
.validator (u) ->
u.error('username', 'is required') unless u.has('username')
user
.name()
.name('John')
.set(name: 'John')
.has('name') # → true
.isNew()
.isValid()
.save (err) ->
.remove (err) ->
.removed
.model # === User
Model.emit('event', [data...])
record.emit('event', [data...])
user
.on 'save', ->
.on 'create', ->
.on 'saving', (data, done) -> done()
.on 'remove', ->
.on 'removing', (data, done) -> done()
.on 'valid', ->
.on 'invalid', ->
.on 'change', ->
.on 'change email', ->
.on 'initializing', (instance, attrs) ->
.on 'initialize', ->
.on 'error', -> failed to save model
.on 'setting', (instance, attrs) -> # on Model#set()
.on 'attr', -> # new attr via Model.attr()
MyPlugin = ->
return (Model) ->
Model.method = ...
Model.prototype.method = ...
Model.attr(...)
Model
A plugin is a function that returns a model decorator (ie, a function that takes in a model and returns a model).
User
.all (err, users) ->
.find id, (err, user) ->
.remove ->
.save ->
.update ->