До сих пор не очень ясно, что вы пытаетесь сделать.Когда вы щелкаете изображение, на какое изображение вы пытаетесь его изменить?Почему это повлияет на уровень масштабирования?
Я проверил ваш jsfiddle и вместо уровня масштабирования, это сам график, смещающийся вверх и вниз, потому что вы заполняете элемент, который ранее не имел высоты.Если вы дадите ему min-height
, график перестанет смещаться вверх и вниз, когда он впервые приобретает ребенка или теряет их всех.
Вот такой ответвление:
#list {
min-height: 25px;
}
Приложение 2019-06-22: Изменить изображение при нажатии mapImage
Чтобы изменить изображение при нажатии, вместо попытки обновить исходные данные для привязки поля свойства, пожалуйста, обновитесвойство href
напрямую.
То есть вместо:
ev.target.dataItem.dataContext.imageURL = "data:image/png;base64,...";
Просто сделайте:
ev.target.href = "data:image/png;base64,...";
Демо-версия ниже была обновлена, чтобы включить это, нажмите Уттар-Прадеш-> затем Meerut (значок с рукой / указателем):
https://jsfiddle.net/notacouch/d6u9ofh7/
Приложение 2019-06-26: Изменить изображение при нажатии «id»
Если вы не согласны с вышесказанным, обязательно закомментируйте строку переназначения изображения: ev.target.href = "...";
.
Если вы хотите изменить изображение mapImage
при нажатии на элемент .selected
, я предлагаю использоватьделегирование событий в родительском #list
div для обработки их событий щелчка вместо воссоздания одного для каждого нового div.Затем в этом обработчике событий, поскольку вы используете jQuery, вы можете проверить его текстовое содержимое с помощью .text()
, преобразовать его в Number
и перебирать mapImages
, пока не будет найдено соответствующее mapImage.dataItem.dataContext.id
.Затем назначьте его дочернее изображение.
Пример обработчика события ниже:
$('#list').on('click', '.selected', function(event) {
var id = Number($(event.target).text());
var totalImages = imageSeries.mapImages.length;
var mapImage;
for(var i = 0; i < totalImages; ++i) {
mapImage = imageSeries.mapImages.getIndex(i);
if (mapImage.dataItem.dataContext.id === id) {
mapImage.children.getIndex(0).href = "";
break;
}
}
});
Демонстрация:
https://jsfiddle.net/notacouch/bxgz74t1/
Или вместо итерации, так как вв этом случае id
является действительным id
из mapImages
, мы можем использовать MapImageSeries
'getImageById()
метод :
$('#list').on('click', '.selected', function(event) {
var id = Number($(event.target).text()); // or via close icon's id
var mapImage = imageSeries.getImageById(id);
if (mapImage) {
mapImage.children.getIndex(0).href = "";
}
});
Демонстрация:
https://jsfiddle.net/notacouch/5ravqhoL/