В настоящее время я использую бесконечную прокрутку для загрузки большего содержимого, содержимое содержит <script>
теги, которые необходимо запустить. Поэтому я использую этот код как ajax-callback
:после завершения ajax, загрузите теги <script>, но только те, у которых определенный идентификатор
JS от нагрузки АЯКС обратного вызова:
function ajaxLoadedCallback() {
// contentElem is the HTML element you've loaded via ajax
scriptx = document.getElementsByTagName("script");
// Load scripts into new array because
// scriptx seems to change as scripts execute, at least in some browsers
scripts = new Array();
for (var idx=0; idx<scriptx.length; idx++) {
if (jQuery(scriptx[idx]).is("#inline-comments")) {
scripts[idx] = scriptx[idx].text;
}
}
console.log (scripts[idx]);
// execute each script in turn
for(idx=0; idx<scripts.length; ++idx) {
if (scripts[idx].length!=0) {
try {
// create a function for the script & execute it
f = new Function(scripts[idx]);
f();
} catch(se) {
} // end try-catch
} // end if
} // end for
}
Каждое содержание пост имеет этот сценарий тег, я хочу, чтобы загрузить:
<script id="inline-comments" >
console.log ('<?php echo $post->ID; ?>' + 'has loaded...');
var tid_<?php echo $post->ID; ?> = setInterval(function() {
if (document.readyState !== 'complete') return;
clearInterval(tid_<?php echo $post->ID; ?>);
inline_comments_ajax_load(<?php echo $post->ID; ?>)
}, 100);
</script>
Получение Uncaught TypeError: не удается прочитать длину свойства неопределенной ошибки в этой строке: if (scripts[idx].length!=0) {
ajax переводит нагрузки в нужное время, но ломается, потому что я предполагаю, что scripts[idx]
пуст. но почему? когда я использую console.log()
, он показывает, когда scriptx[idx]
имеет идентификатор и имя идентификатора.
ОБНОВЛЕНИЕ Спасибо PSL! console.log
показывает, что он найти сценарии, но scripts.length возвращается ноль
function ajaxLoadedCallback() {
scriptx = document.getElementsByTagName("script");
scripts = new Array();
for (var idx=0; idx<scriptx.length; idx++) {
if (jQuery(scriptx[idx]).is(".inline-comments-script")) {
console.log (".inline-comments-scriptfound!");
console.log ("####### .text #######");
console.log (scriptx[idx].text);
console.log ("####### .innerHTML ######");
console.log (scriptx[idx].innerHTML);
scripts.push = scriptx[idx].innerHTML;
}
}
console.log ("####### END ######");
console.log ("Found "+scripts.length+ " script(s)");
// execute each script in turn
for(idx=0; idx<scripts.length; ++idx) {
var content = scripts[idx];
if (content.length) {
try {
// create a function for the script & execute it
f = new Function(content);
f();
} catch(se) {
} // end try-catch
} // end if
} // end for
}
теперь работает! См. Ответ PSL ниже - вы также можете увидеть его вживую, если у вас есть wordpress: https://github.com/MattMcFarland/inline-ajax-comments - отлично работает!
Вместо перебирает все элементы сценария использовать 'document.getElementById ('инлайн-комментарии');' – jantimon
Пробовал, что не работал – docodemore
Изменить 'scripts.push = ScriptX [IDX] .innerHTML,' 'для скриптов .push (scriptx [idx] .innerHTML); 'см. мой ответ для синтаксиса ... – PSL