Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
27 / 22 / 6
Регистрация: 13.12.2012
Сообщений: 159

CreateElement из строки

12.04.2017, 21:46. Показов 1188. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый.
Имею ajax запрос, который возвращает мне кусок разметки. Но возвращает он мне ее в виде строки.
Далее мне нужно эту разметку запихнуть в DocumentFragment.

тоесть мне нужно написать примерно такой код
JavaScript
1
2
3
var fragment = document.createDocumentFragment();
var node = document.createElement(xhr.responseText);
fragment .appendChild(node);
но беда в том что в createElement я не муго передать ответ ajax чтобы создать ноду, а в appendChild нужно передать именно ноду. как быть подскажите пож.

Добавлено через 4 часа 39 минут
неужели никто не поможет?)
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.04.2017, 21:46
Ответы с готовыми решениями:

CreateElement
Помогите разобраться с примером , начал изучать js с javascript.ru , не могу понять почему не создается элемент, вообщем ничего не...

CreateElement не работает
<html> <body> <img src="1.jpg" onclick="fclick();"> <script> function fclick() { var newimage =...

document.createElement('TD')
есть два файла. Form2.html: <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> ...

7
Эксперт PHP
 Аватар для Fedor Vlasenko
936 / 693 / 236
Регистрация: 01.02.2015
Сообщений: 1,848
13.04.2017, 00:30
HTML5
1
<div id="test"></div>
JavaScript
1
2
3
4
5
6
7
window.onload = function() {
  var fragment = document.createDocumentFragment();
  var div = document.createElement("div");
  div.innerHTML  = '<div>My test</div>';
  fragment.appendChild(div.childNodes[0]);
  test.appendChild(fragment);
};
Как вариант
0
the hardway first
Эксперт JS
 Аватар для j2FunOnly
2475 / 1847 / 910
Регистрация: 05.06.2015
Сообщений: 3,610
13.04.2017, 09:41
drmedus, element.insertAdjacentHTML()
0
27 / 22 / 6
Регистрация: 13.12.2012
Сообщений: 159
13.04.2017, 09:57  [ТС]
j2FunOnly, вот так не работает

JavaScript
1
2
3
4
var fragment = document.createDocumentFragment();
var node = document.createElement('div');
node.insertAdjacentHTML('afterbegin',xhr.responseText);
fragment .appendChild(node);
или я не так понял?
0
Фрилансер
735 / 352 / 96
Регистрация: 05.05.2014
Сообщений: 2,621
13.04.2017, 10:03
HTML5
1
xhr.responseText
выложите полный код с асинхронным кодом
0
27 / 22 / 6
Регистрация: 13.12.2012
Сообщений: 159
13.04.2017, 10:24  [ТС]
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
var rowTemplate = document.createDocumentFragment();
                var xhr = new XMLHttpRequest();
                xhr.open('GET', 'templates/row.html', false);
                xhr.send();
                if (xhr.status != 200) {
                    alert( xhr.status + ': ' + xhr.statusText ); // пример вывода: 404: Not Found
                } else {
                    var node = document.createElement('div');
                    node.insertAdjacentHTML('beforebegin',xhr.responseText);
                    rowTemplate.appendChild(node);
                    return rowTemplate;
                }
Добавлено через 1 минуту
в row.html просто кусочек простого html
0
Superposition
 Аватар для Padimanskas
950 / 615 / 256
Регистрация: 27.10.2013
Сообщений: 2,083
13.04.2017, 10:56
Лучший ответ Сообщение было отмечено drmedus как решение

Решение

JavaScript
1
2
3
4
5
var fragment = document.createDocumentFragment();
var element = document.createElement('div');
element.innerHTML = '<h1>hello!</h1>';
fragment.appendChild(element.children[0]);
document.body.appendChild(fragment);
1
27 / 22 / 6
Регистрация: 13.12.2012
Сообщений: 159
13.04.2017, 10:57  [ТС]
Padimanskas, спасибо, сам нашел только что это решение. На поверхности было.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.04.2017, 10:57
Помогаю со студенческими работами здесь

Не принимает createElement
window.onload = function () { &quot;use strict&quot;; createResultTable (&quot;resultTable&quot;); } function createResultTable ( id ) { ...

DocumentFragment или createElement
Подскажите, что лучше использовать для динамической загрузки данных на страницу? Использую createElement, но он занимает достаточно много...

Call to undefined method DOMElement::createElement()
Здравствуйте. Подскажите пожалуйста, почему может возникать эта ошибка.

Создание формы с помощью методов createElement и createAttribute
Здравствуйте! Я бы хотел обратиться к знающим людям за помощью! Создаю полноценную форму через создание узлов и присваивания значений этим...

Почему не добавляется изображение на страницу? не работает createElement
&lt;!doctype html&gt; &lt;html lang=&quot;en&quot;&gt; &lt;head&gt; &lt;script src=&quot;main.js&quot; async&gt;&lt;/script&gt; &lt;link rel=&quot;stylesheet&quot; href=&quot;style.css&quot;...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru