Как-то так. Только вложенность тегов не поддерживается. Если надо морочтесь с рекурсией самостоятельно.)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <script type="text/javascript"> window.onload=function() { var doc=document.getElementById('test'); var text=doc.innerText?'innerText':'textContent'; var cn=doc.childNodes, i=cn.length; //берем все ноды var strings=[]; while(i--){ strings.unshift(cn[i][text]); cn[i][text]=''; } //проходим собирая всеь текст в вспогательный массив strings, то на странице остаются лишь теги(можно добавить проверку на тип ноды и не текстовым добавлять displasy:none) var ch=0,node=0; function echo() { if(strings[node].length<=++ch){ ch=0; if(!strings[++node]){ //в случае если нод больше нет - омтанавливаемся clearInterval(interval) return false; } } cn[node][text]+=strings[node].charAt(ch); } var interval = setInterval(echo,50); } </script> </head> <body> <div id="test">«На наш взгляд, <a href=''>иностранные военные</a> присутствия в Афг<b>анистане могут</b> и должны предпринять более активные усилия в борьбе с наркопроизводством в этой стране, раз уж <i>они практически</i> взяли на себя ответственность за вопросы безопасности в Афганистане», - сказано в сообщении.</div> </body> </html> |
печатная машинка и сохранение тегов
Вариант ... составляем масив текстовых нод, обнуляем их содержимое и востанавливаем по таймеру ... сохраняется любая вложенность тегов так как структура HTML остаёться неизменной
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> </head> <body> <div id="test">«На наш взгляд, <a href=''>иностранные военные</a> присутствия в Афг<b>анис<i>тане</i> могут</b> и должны предпринять более активные усилия в борьбе с наркопроизводством в этой стране, раз уж <i>они практически</i> взяли на себя ответственность за вопросы безопасности в Афганистане», - сказано в сообщении.</div> <script language="JavaScript" type="text/javascript"> var textNodes = []; var textNodes_data = []; var i=0; function search_textNodes(b) { b = b.childNodes; for (var c = 0, d = b.length; c < d; c++) { var a = b[c]; if (a.nodeType == 3) { textNodes.push(a); textNodes_data.push(a.data); a.data = "" } else a.hasChildNodes() && search_textNodes(a) } }; var d = document.getElementById('test'); search_textNodes(d); function str_write() { var a = textNodes_data[i]; if (a) { textNodes[i].data += a.charAt(0); textNodes_data[i] = a.substr(1) } else i++; i < textNodes.length && setTimeout(arguments.callee, 100) }; str_write() </script> </body> </html> |
рони, Aetae спасибо за помощь, это то, что нужно. Буду разбираться как это работает.
|
Часовой пояс GMT +3, время: 01:47. |