我目前正在做一个项目,在这个项目中,我在输入框中键入一个关键字,当我单击“发送”时,它会通过一个类似于(localhost/json-status.php?query=inputtext),它以json格式返回“query=”之后的任何内容。现在我已经用jQuery完成了这个,我正在尝试在backbonejs中再次做这个。$("#updateStatus").click(function(){varquery=$("#statusBar").val();varurl="json-status.php"+"?query="+query;$.getJSON(url,function(jso
我不明白为什么当我在this.model上运行this.model.fetch()而不是在view.render()中时,它会在view.intialize()中定义。define(['jquery','underscore','backbone','text!templates/example.html'],function($,_,Backbone,exampleTemplate){varexampleView=Backbone.View.extend({el:$('body'),initialize:function(){this.model.set({_id:this.opti
想象一个像这样的模型/集合:varAModel=Backbone.Model.extend({defaults:{a:'astring',b:'anotherstring',c:'yetanotherstring'}});varACollection=Backbone.Collection.extend({model:AModel,comparator:function(amodel){...}});如何编写比较器来实现多级排序?我想按AModel的a属性排序,然后按其b属性排序,然后按其c属性。我拼凑了一个看起来像这样的比较器,但我想知道是否有更好/更智能的方法?comparator
我可以将我的模板放在单独的.html文件中,然后在我的index.html中引用它们吗?索引.html:项目列表-tmpl.html:我试过了,但问题是它没有在index.html上显示模板,但它加载在正确的位置(使用Firebug查看)更新找到了一个可能的解决方案,但不推荐用于生产环境。 最佳答案 从http://coenraets.org/blog/2012/01/backbone-js-lessons-learned-and-improved-sample-app/#comment-35324得到这个为此创建一个单独的js文件
我有以下代码:varGoalPanelView=Backbone.View.extend({//BindtothegoalpanelDOMelementel:$("#sidebar-goals"),//Initializethecollectioninitialize:function(){this.collection=Goals;this.collection.bind('add',this.appendItem);},//CreateanewgoalwhenauserpressesenterintheentergoalinputcreateOnEnter:function(e){
只是一个关于将Backbone.js与LocalStorage一起使用的非常简短的问题:我在LocalStorage中存储了一个事物列表(主干集合)。当我的网站在多个浏览器窗口/选项卡中打开并且两个窗口中的用户都向列表中添加内容时,一个窗口的更改将覆盖另一个窗口中所做的更改。如果您想自己尝试,只需使用示例Backbone.jsTodo应用:打开http://backbonejs.org/examples/todos/index.html在两个浏览器选项卡中在第一个选项卡中添加项目“item1”,在第二个选项卡中添加“item2”刷新两个选项卡:“item1”将消失,您将只剩下“item
是否可以像这样在backbone中全局覆盖collection.add方法:Backbone.Collection.prototype._add=Backbone.Collection.prototype.add;Backbone.Collection.prototype.add=function(models,options){var=newModels=models.items;Backbone.Collection.prototype._add(newModels,options);}我使用的api始终包含下一级集合的实际模型。在items下,我发现自己覆盖了所有集合的.add方
我有一个包含名称和日期的待办事项列表。我希望能够使用标题或日期对列表进行排序。我该怎么做?比较器只允许一种类型的排序。谢谢。 最佳答案 可以在比较器中实现更多逻辑,以便您可以抽象出一些排序逻辑:varCollection=Backbone.Collection.extend({model:myModel,order:'name'comparator:function(model){if(this.order==='name'){returnmodel.get('name');}else{returnmodel.get('date')
我有一个Marionette.CompositeView需要渲染一个集合。我想在fetch和add操作上过滤这个集合。我尝试使用以下代码(1),但出现以下错误(2)。任何想法,谢谢。(1)varmyCompositeView=Marionette.CompositeView.extend({initialize:function(){this.collection=app.taskCollection.where({type:'todo'});}});(2)//UncaughtTypeError:Objecthasnomethod'on' 最佳答案
我需要清空一个集合,按顺序移除每一项。this.nodes.each(function(node){this.nodes.remove(node);},this);不起作用,因为随着每个节点被删除,它会更改集合的长度。制作一个临时数组,然后迭代该数组。有没有更好的办法? 最佳答案 尝试this.nodes.reset()除非你需要remove事件。否则:varnodes=this.nodes;while(nodes.length>0)nodes.remove(nodes.at(0));