簡體   English   中英

使用動態生成的對象數組填充ember-power-select時,無法在Array.toString(本地)將對象轉換為原始值

[英]Cannot convert object to primitive value at Array.toString (native) when populating ember-power-select with array of objects generated dynamically

我需要用商店中的對象填充電源選擇,但是我只能使用硬編碼數組myOptions顯示選項。 我試圖動態生成myOption2 ,並且顯然得到了與myOptions相同的輸出,但是它拋出錯誤:

ember.debug.js:19845 Uncaught TypeError: Cannot convert object to primitive value
at Array.toString (native)
at Object.addListener (http://localhost:4200/assets/vendor.js:30682:88)
at Object.addObserver (http://localhost:4200/assets/vendor.js:34026:23)
at Array.addObserver (http://localhost:4200/assets/vendor.js:47679:27)
at Class.updateOptions (http://localhost:4200/assets/vendor.js:88968:17)
at invoke (http://localhost:4200/assets/vendor.js:11825:16)
at Queue.flush (http://localhost:4200/assets/vendor.js:11891:11)
at DeferredActionQueues.flush (http://localhost:4200/assets/vendor.js:11699:17)
at Backburner.end (http://localhost:4200/assets/vendor.js:11013:25)
at Backburner.run (http://localhost:4200/assets/vendor.js:11135:18)

function addListener(obj, eventName, target, method, once) {
_emberMetalDebug.assert('You must pass at least an object and event name to Ember.addListener', !!obj && !!eventName);
_emberMetalDebug.deprecate('didInitAttrs called in ' + (obj && obj.toString && obj.toString()) + '.', eventName !== 'didInitAttrs', {
  id: 'ember-views.did-init-attrs',
  until: '3.0.0',
  url: 'http://emberjs.com/deprecations/v2.x#toc_ember-component-didinitattrs'
});

//template.hbs

{{#power-select options=myOptions onchange=(action "foo") as |opt|}}
  {{opt.name}}
{{/power-select}}

//component.js

myOptions: [
  { name: 'First Option' },
  { name: 'Second Option' }
],

myOptions2: [],

didReceiveAttrs() {
  this.get('model.content').forEach((option) => {
    this.get('myOptions2').push(option._data);
  });
}


//#=> myOptions: [{name: 'First Option'},{"name":"Second Option"}]
//#=> myOptions2 [{name: 'First Option'},{"name":"Second Option"}]

提前致謝!

而不是push你需要使用pushObject ,只有觀測,計算性能將火和模板將自動更新。

this.get('myOptions2').pushObject(option._data)

話雖如此,我不確定這是否可以解決您的問題。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM