Я делаю поиск и замену во встроенных SVG. Часть веб-службы печати, которую я создаю.
У меня есть текстовые теги внутри SVG, такие как {name}, {title}, {phone} и т. Д.
Я написал скрипт для замены этих значений, и он обновляет встроенный SVG. В настоящее время работает хорошо.
Он использует плагин jQuery SVG для загрузки SVG.
// Callback after loading external document
function loadDone(svg, error) {
svg.configure({viewBox: '0 0 315 180', width: 579, height: 331}, true); //resize the svg. viewBox must be the same size as the initial width defined in the SVG
var textElems = document.getElementsByTagNameNS('http://www.w3.org/2000/svg', 'tspan');
var doc = document.getElementById('svgload').contentDocument;
for (var i = 0; i < textElems.length; i++) {
var id = textElems[i].childNodes[0].nodeValue;
id = id.replace("{",""); //remove brackets {}
id = id.replace("}","");
alert(id);
$("#formContainer").append('<p>' + capitalize(id) + ': <input type="text" id="' + id + '" class="replace" />\n');
$("#formContainer").append('<input type="hidden" id="' + id + 'PrevVal" value="{' + id + '}" /></p>');
}
$('.replace').keyup(function() {
var prevValID = $(this).attr("id") + "PrevVal"; //determine the hidden input id
var oldVal = $("#"+prevValID).val(); //set oldVal to the hidden input value, first time it's {id}
var currentVal = $(this).val(); //set the currentVal to the user inputted value
changeText(oldVal,currentVal); //swap the oldVal with the currentVal
$('#'+prevValID).attr("value",currentVal); //set the hidden input value to the last inputted user value
svg.configure({viewBox: '0 0 315 180', width: 579, height: 331}, true); //"resize" to svg to clear the text. some browsers break the new text until the svg is "zoomed", or in this case, resized
});
function changeText(oldVal,newVal) { //swap the values inside the SVG file
for (var i = 0; i < textElems.length; i++) {
if (textElems[i].childNodes[0].nodeValue == oldVal) {
textElems[i].childNodes[0].nodeValue = newVal;
}
}
}
}
function capitalize(str) { //capitalize first letter of words
var firstLetter = str.slice(0,1);
return firstLetter.toUpperCase() + str.substring(1);
}
Хотя есть некоторые ошибки. Например, поскольку я создаю скрытые элементы div для хранения предыдущего значения текста SVG, можно создать ситуацию, когда при вводе одной и той же вещи в два текстовых поля создаются два идентичных идентификатора, а затем при дальнейшем вводе обновляются оба текстовых элемента во встроенном SVG. Он также не любит теги с пробелами, например, {полное имя} против {имя}.
Любые предложения о том, как очистить все это? Я знаю, что должен быть в состоянии обнаружить теги (поиск {}), а затем получить связанный с ними текст или идентификатор tspan и обновить значение узла таким образом, однако у меня серьезный блок кодирования, и я не могу начать с это!