@Alex_vs_Predator
Начинающий веб-разработчик

Функция .html('') не видит полностью код?

Добрый вечер, всем!
Скажите пожалуйста, функция .html() почему не видит весь код? Т.е. в консоле выдает ошибку.
Написал скрипт для оптимизации карты и поместил его в файл script.js
var reservation = $('.reservation');
    var reservationTop = reservation.offset().top;
    $(window).bind('scroll', function () {
        var windowTop = $(this).scrollTop();
        if (windowTop > reservationTop) {
            $('.map').html('<script charset="utf-8" async src="https://api-maps.yandex.ru/services/constructor/1.0/js/?um=constructor%3A45374b4f36193c2c3bb5a22a9bffed35b78e3e041596ce43450258bbf7529fad&amp;width=100%25&amp;height=598&amp;lang=ru_UA&amp;scroll=false"> </script>')
            $(window).unbind('scroll')
        } 
    });


НО как оказалось, по заданию этот скрипт мне необходим в самом файле index.html

Когда вставил этот код в index.html, то в консоле выдает ошибку:
Uncaught SyntaxError: Invalid or unexpected token

Кусок кода подчеркивает красным
обычным цветом, как будто закрывающая скобка функций .html('') не видит код

В чем беда?
За ранее благодарен!!!
  • Вопрос задан
  • 65 просмотров
Решения вопроса 1
bingo347
@bingo347 Куратор тега JavaScript
Crazy on performance...
Во-первых, если js внутри html, то строки содержащие </script> нужно разбивать:
$('.map').html('<script charset="utf-8" async src="https://api-maps.yandex.ru/services/constructor/1.0/js/?um=constructor%3A45374b4f36193c2c3bb5a22a9bffed35b78e3e041596ce43450258bbf7529fad&amp;width=100%25&amp;height=598&amp;lang=ru_UA&amp;scroll=false"> </sc' + 'ript>')


Во-вторых, не уверен, что jQuery настолько умный, чтоб автоматом нормализовать вставку скрипта, по этому меняем эту строку так:
var script = document.createElement('script');
script.async = true;
script.src = 'https://api-maps.yandex.ru/services/constructor/1.0/js/?um=constructor%3A45374b4f36193c2c3bb5a22a9bffed35b78e3e041596ce43450258bbf7529fad&amp;width=100%25&amp;height=598&amp;lang=ru_UA&amp;scroll=false';
$('.map').append(script);
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
@DanKud
Экранируйте закрывающий слэш $('.map').html('.....<\/script>';
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 06:06
1500 руб./в час
22 нояб. 2024, в 06:04
1 руб./за проект
22 нояб. 2024, в 03:54
1500 руб./за проект