本教程演示了使用easeljs和backbone.js构建一个简单的拖放应用程序。 主干通过模型,集合和视图结构该应用程序,而Easeljs简化了HTML5帆布操作。尽管该项目并不是严格必要的骨干,但它是对其功能的有用介绍。
密钥概念:
render()
> change
听集合的CanvasView
。
Easeljs管理视觉元素,而backbone.js处理数据和逻辑,为拖放实现创建了有效的组合。add
>
renderStone()
创建此目录结构:
包括JavaScript文件和一个帆布元素:
<code>. |-- index.html +-- js |-- main.js |-- models | +-- stone.js +-- views +-- view.js</code>
骨干模型:index.html
<code class="language-html"><!DOCTYPE html> <title>Drag and Drop with Backbone and EaselJS</title> <canvas id="testcanvas" height="640" width="480"></canvas> </code>
:
这定义了一个简单的模型和ajs/models/stone.js
。
<code class="language-javascript">var Stone = Backbone.Model.extend({}); var StoneCollection = Backbone.Collection.extend({ model: Stone });</code>
Stone
StoneCollection
:
js/main.js
这会创建一个easeljs阶段并实例化
<code class="language-javascript">$(document).ready(function() { var stage = new createjs.Stage("testcanvas"); var view = new CanvasView({stage: stage}).render(); });</code>。
CanvasView
:
js/views/view.js
>初始化舞台,收集和事件听众。
<code class="language-javascript">var CanvasView = Backbone.View.extend({ initialize: function(args) { this.stage = args.stage; this.stage.enableMouseOver(20); this.collection = new StoneCollection(); this.rakeOffsets = { /* ... (rake dimensions) ... */ }; this.listenTo(this.collection, "add", this.renderStone, this); this.listenTo(this.collection, "remove", this.renderRake, this); this.listenTo(this.collection, "reset", this.renderRake, this); }, render: function() { this.renderRake(); this.stage.update(); createjs.Ticker.addEventListener("tick", this.stage); createjs.Ticker.setInterval(25); createjs.Ticker.setFPS(60); }, renderRake: function() { /* ... (rake rendering and click handler) ... */ }, renderStone: function(model) { /* ... (stone rendering and drag-and-drop logic) ... */ } });</code>>和
处理视觉方面。 (完整的CanvasView
和render()
>函数,包括拖放实现,太广泛了,以至于在此处包括,但在原始文章的GitHub存储库中可用)。renderRake()
>
renderStone()
剩余代码(拖放逻辑,辅助功能)将在renderRake()
>内部和renderStone()
内的其他辅助功能。 有关完整的实施详细信息,请参阅原始文章。
这种修订后的响应提供了更简洁,更结构化的概述,突出了关键组件及其相互作用。 请记住,请咨询原始文章以获取完整的代码和拖放实现的详细说明。renderStone()
>
以上是使用骨干和easeljs实施拖放-SitePoint的详细内容。更多信息请关注PHP中文网其他相关文章!