view source
JavaScript
console.log('js-backbone');
var object = {};
_.extend(object, Backbone.Events);
object.on("alert", function(msg) {
console.log("Triggered " + msg);
});
object.trigger("alert", "an event");
var model = new Backbone.Model({
title : true
});
model.set({'name': 'Taro'});
console.log(model.has('name'));
model.on("change", function (model) {
console.log(model.name); // undefined
console.log(model.toJSON());
console.log(" changed!");
});
model.set({'name': 'Hanako'});
model.set({'html': '<a>text</a>'});
console.log(model.get('name'));
console.log(model.escape('html'));
console.log(model.has('title'));
model.unset('title')
/*
var Model2 = new Backbone.Model.extend({
validate: function (attrs) {
if (_.isEmpty(attrs.name)) {
return "Invalid!";
}
}
});
var model2 = new Model2();
*/
/*
model2.on("error", function (model2, error) {
console.log(error);
});
model2.set({name: "a"});
model2.set({name: ""});
*/
var DocumentView = Backbone.View.extend({
events: {
"dblclick" : "open",
"click .icon.doc" : "select",
/*
"contextmenu .icon.doc" : "showMenu",
"click .show_notes" : "toggleNotes",
"click .title .lock" : "editAccessLevel",
"mouseover .title .date" : "showTooltip"
*/
},
render: function() {
console.log(this.model);
this.$el.html(this.template(this.model.attributes));
return this;
},
open: function() {
window.open(this.model.get("viewer_url"));
},
select: function() {
console.log(this.model);
this.model.set({selected: true});
},
});
var view = new DocumentView();
CSS
HTML
ページのソースを表示 : Ctrl+U , DevTools : F12
view-source:https://hi0a.com/demo/-js/js-backbone/
ABOUT
hi0a.com 「ひまアプリ」は無料で遊べるミニゲームや便利ツールを公開しています。
プログラミング言語の動作デモやWEBデザイン、ソースコード、フロントエンド等の開発者のための技術を公開しています。
必要な機能の関数をコピペ利用したり勉強に活用できます。
プログラムの動作サンプル結果は画面上部に出力表示されています。
環境:最新のブラウザ GoogleChrome / Windows / Android / iPhone 等の端末で動作確認しています。
画像素材や音素材は半分自作でフリー素材配布サイトも利用しています。LINK参照。
動く便利なものが好きなだけで技術自体に興味はないのでコードは汚いです。
途中放置や実験状態、仕様変更、API廃止等で動かないページもあります。