У меня есть состояние с именем this.state.devices
, которое представляет собой массив объектов device
.
Скажем, у меня есть функция
updateSomething: function (device) {
var devices = this.state.devices;
var index = devices.map(function(d){
return d.id;
}).indexOf(device.id);
if (index !== -1) {
// do some stuff with device
devices[index] = device;
this.setState({devices:devices});
}
}
Проблема заключается в том, что каждый раз, когда вызывается this.updateSomething
, весь массив обновляется, и поэтому вся DOM возвращается повторно. В моей ситуации это заставляет браузер замораживать, поскольку я вызываю эту функцию почти каждую секунду, и есть много объектов device
. Однако при каждом вызове фактически обновляется только одно или два из этих устройств.
Каковы мои варианты?
ИЗМЕНИТЬ
В моей точной ситуации a device
- это объект, который определяется следующим образом:
function Device(device) {
this.id = device.id;
// And other properties included
}
Итак, каждый элемент в массиве state.devices
является конкретным моментом этого device
, то есть где-то у меня было бы:
addDevice: function (device) {
var newDevice = new Device(device);
this.setState({devices: this.state.devices.push(device)});
}
Мой обновленный ответ, как на updateSomething
, у меня есть:
updateSomething: function (device) {
var devices = this.state.devices;
var index = devices.map(function(d){
return d.id;
}).indexOf(device.id);
if (index !== -1) {
// do some stuff with device
var updatedDevices = update(devices[index], {someField: {$set: device.someField}});
this.setState(updatedDevices);
}
}
Проблема в том, что я получаю сообщение об ошибке, которое не может читать значение undefined id
, и оно исходит от function Device()
; кажется, что новый new Device()
вызывается, а device
не передается ему.