Я хочу связать координаты x, y прямоугольника (записывается как «Координата»). И перетащите прямоугольник, надеясь, что запись (координата x, y) изменится синхронно.
Ниже приведена часть кода. (Полный код jsbin )
HTML
<tr ng-repeat="item in data">
<td>({{ item.x }}, {{ item.y }})</td>
<td>{{ item.width }}</td>
<td>{{ item.height }}</td>
</tr>
JS
$scope.data = [{ 'x': 30, 'y': 50, 'width': 90, 'height': 70 }];
var drag = d3.drag()
.on('drag', function (d) {
d3.select(this)
.attr('x', d.x = d3.event.x)
.attr('y', d.y = d3.event.y)
})
.on('end', function (d) {
//update coordinate x ,y to array
arrayNum = this.id;
$scope.data.splice(arrayNum, 1, { 'x': d.x, 'y': d.y, 'width': d.width, 'height': d.height });
console.log($scope.data);
});
У меня также есть $ scope.data.splice для обновления массива. И это действительно обновляет $ scope.data .
Но это не работает в представлении браузера. Как я могу изменить? Или на что я могу сослаться? Большое спасибо!