Javascript 使用新的数组元素更新backbone.js模型
我有一个类似于下图的backbone.js模型Javascript 使用新的数组元素更新backbone.js模型,javascript,backbone.js,Javascript,Backbone.js,我有一个类似于下图的backbone.js模型 Filters = Backbone.Model.extend({ defaults : { title: [ ["title1", "easy"], ["title2", "hard"] ] } }); 我试图将一个元素添加到第一级数组中,这样模型就会变成: Filters = Backbone.Model.extend({ defaults : { title: [ ["title1",
Filters = Backbone.Model.extend({
defaults : {
title: [ ["title1", "easy"], ["title2", "hard"] ]
}
});
我试图将一个元素添加到第一级数组中,这样模型就会变成:
Filters = Backbone.Model.extend({
defaults : {
title: [ ["title1", "easy"], ["title2", "hard"], ["title3", "medium"] ]
}
});
我现在掌握的代码是:
function setFilters() {
var options = {};
for (var facet in facets) {
for (var facetKey in facets[facet]) {
if (!filterExists(facetKey)) {
options[facetKey] = new Array(new Array(facets[facet][facetKey], "equals"));
}
else {
(filters[facetKey]).push(new Array(facets[facet][facetKey], "equals"));
}
}
}
filters.set(options);
}
函数filterExists只是检查模型中是否存在键“title”。当我运行它时,它说过滤器[facetKey]未定义。但这不是我需要将元素推入的第一级数组吗?您可以使用
.get()
和.set()
函数访问模型属性,或者直接通过.attributes
属性访问:
或
无论如何,这是您的转换函数,它可能工作,也可能不工作:
function setFilters() {
for (var facet in facets) {
for (var facetKey in facets[facet]) {
var f = [ facets[facet][facetKey], "equals" ];
if( filterExists(facetKey)) {
// OR: if( filters.attributes[ facetKey ]){
filters.attributes[ facetKey ].push( f );
}else{
filters.attributes[ facetKey ] = [ f ];
}
}
}
// trigger change event for all attributes
filters.set( filters.attributes );
}
奖金:
(filters.attributes[ facetKey ] = filters.attributes[ facetKey ] || [] ).push(f);
Offtopic:newarray(newarray(facets[facet][facetKey],“equals”)为什么不编写更短的
[[facets[facet][facetKey],“equals”]
?过滤器
是全局变量吗<代码>过滤器或过滤器
?@biziclop是的,过滤器是一个全局变量。感谢您提供有关数组的提示。另外{{{“title1”,“easy”},{“title2”,“hard”}
应该是[[“title1”,“easy”],[“title2”,“hard”]]
{}
用于创建对象:{name:'Joe',city:'London'}
@biziclop,是的,我现在将更改它以防止将来混淆。但是这会触发更改
事件吗?仅使用.set()
将触发任何事件,直接访问对象的属性无法触发任何事件(除非二传手以某种方式参与)。我认为这是一个很好的答案,因为它完成了@kaspnord的要求,但由于“事件”触发不会自动发生,因此可能会导致问题。例如,如果有视图等待更改以重新呈现自己,等等。也许您应该在添加元素后手动触发事件?谢谢大家,这很有效!看起来就像我把models对象当作数组一样,这就是我无法访问它的原因。另外,感谢“filterExists”的替代方案……它更好:)filters.set('facetKey',filters.get('facetKey')。push(…);//主干0.9 FTW
将不起作用,因为array.push()返回的是数组的长度,而不是数组本身。你必须把它分开
function setFilters() {
for (var facet in facets) {
for (var facetKey in facets[facet]) {
var f = [ facets[facet][facetKey], "equals" ];
if( filterExists(facetKey)) {
// OR: if( filters.attributes[ facetKey ]){
filters.attributes[ facetKey ].push( f );
}else{
filters.attributes[ facetKey ] = [ f ];
}
}
}
// trigger change event for all attributes
filters.set( filters.attributes );
}
(filters.attributes[ facetKey ] = filters.attributes[ facetKey ] || [] ).push(f);