灰烬1.13升级

时间:2019-03-14 09:56:49

标签: javascript ember.js ember-1

我正在将代码从Ember 1.0.4升级到Ember 1.13。当我使用ember 1.13执行以下代码时,出现错误

title: Ember.computed('content.title', 'managedObject.isHome', 'managedObject.finalManagedObject', {
                set: function(name, value) {
                    this.set('content.title', value);
                },
                if (this.get('content.title') !== undefined) {
                    return title;
                }
                if (this.get('managedObject') == Core.rootNode) {
                    return "Home";
                }
                get: function() {
                  return this.get('managedObject.label') || this.get('managedObject.finalManagedObject.displayName');
                }
            }),

执行代码时出现以下错误。

Uncaught SyntaxError: Unexpected token this

3 个答案:

答案 0 :(得分:0)

您正在使用一个对象来定义计算属性。该对象必须具有get,并且可以具有set函数。两者都存在。但是您还有另外六个对象定义中的无效语法。您正在尝试构造这样的对象:

{
  set: function(name, value) {
    this.set('content.title', value);
  },
  if (this.get('content.title') !== undefined) {
     return title;
  }
  if (this.get('managedObject') == RSuite.rootNode) {
    return "Home";
  }
  get: function() {
    return this.get('managedObject.label') || this.get('managedObject.finalManagedObject.displayName');
  }
}

该对象的有效部分是:

{
  set: function(name, value) {
    this.set('content.title', value);
  },
  get: function() {
    return this.get('managedObject.label') || this.get('managedObject.finalManagedObject.displayName');
  }
}

根据您的babel配置,您可以将其简化为:

{
  set(name, value) {
    this.set('content.title', value);
  },
  get() {
    return this.get('managedObject.label') || this.get('managedObject.finalManagedObject.displayName');
  }
}

我希望现在明白了。这与从Ember 1.0.4升级到Ember 1.13无关。请记住,Ember 1.13很老。 2.0于三年前发布。因此,我强烈建议您继续迁移,直到您至少达到2.18。

答案 1 :(得分:0)

我通过使用以下代码得到了答案:

title: Ember.computed('content.title', 'managedObject', 'managedObject.label', 'managedObject.finalManagedObject.displayName', {
                set: function(titleKey, newTitle) {
                    this.set('content.title', newTitle);
                    if (newTitle !== undefined) {
                        return newTitle;
                    } else if (this.get('managedObject') === Core.rootNode) {
                        return 'Home';
                    }
                    return this.get('managedObject.label') || this.get('managedObject.finalManagedObject.displayName');
                },      
                get: function() {
                    var title = this.get('content.title');
                    if (title !== undefined) {
                        return title;
                    } else if (this.get('managedObject') === Core.rootNode) {
                        return 'Home';
                    }
                    return this.get('managedObject.label') || this.get('managedObject.finalManagedObject.displayName');
                }
            }),

感谢您的建议Rinold Simon和jelhan。

答案 2 :(得分:-2)

我认为this引用丢失了。尝试用以下代码替换您的代码

title: Ember.computed('content.title', 'managedObject.isHome', 'managedObject.finalManagedObject', {
  set(name, value) {
    this.set('content.title', value);
  },
  get() {
    return this.get('managedObject.label') || this.get('managedObject.finalManagedObject.displayName');
  }      
  if (this.get('content.title') !== undefined) {
    return title;
  }
  if (this.get('managedObject') == RSuite.rootNode) {
    return "Home";
  }
}),