Получение выборки не определено в Internet Explorer 11? - PullRequest
0 голосов
/ 11 января 2019

Я столкнулся с проблемой, когда мой код ниже говорит, что 'fetch' is undefined в Internet Explorer 11. Я использую последнюю версию jquery jquery-3.3.1.min.js, и я даже попытался $.ajax вместо fetch, но это помогло не работа. Может ли кто-нибудь помочь мне решить эту проблему, с моим кодом ниже. Это может даже работать в ie11. большое спасибо!

Вот мой код:

"use strict";

$(function () {
    var myData = [];


    $.get("#{request.contextPath}/JobSearchItem.xhtml", function (data) {

        $("#searchTextField").autocomplete({
            minLength: 2,
            source: myData,
            select: function select(event, ui) {
                event.preventDefault();
                var url = '#{request.contextPath}/index.xhtml';
                var searchValue = ui.item.value;
                var data = new FormData();
                data.append('searchValue', searchValue);
                fetch(url, {
                    body: data,
                    method: "post"
                }).then(function (res) {
                    return res.text();
                }).then(function (text) {
                    $('#results').append($(text).find('#textTable'));
                    $('#results').append($(text).find('table'));
                    $('#results').append($(text).find('#bestTable'));
                    $("#clearone").show();
                });
            },
            response: function response(event, ui) {
                if (!ui.content.length) {
                    var message = { value: "", label: "NO SEARCH RESULT FOUND" };
                    ui.content.push(message);
                }
            }

        });


        $.each(data, function (k, v) {
            myData.push({
                id: v.id,
                label: v.label,
                value: v.id

            });
        });
    });


    $("#sJobClass").change(function () {
        var jobClassCd = $(this).val();
        if (jobClassCd !== 0) {
            var url = '#{request.contextPath}/index.xhtml';
            var searchValue = $('#sJobClass').val();
            var data = new FormData();
            data.append('searchValue', searchValue);
             fetch(url, {
                body: data,
                method: "post"
            }).then(function (res) {
                return res.text();
            }).then(function (text) {
                $('#results').append($(text).find('#textTable'));
                $('#results').append($(text).find('table'));
                $('#results').append($(text).find('#bestTable'));
                $("#clearone").show();
            });
        };
    });


});

Ответы [ 2 ]

0 голосов
/ 11 января 2019

Хотя, если вы уже используете jQuery, имеет смысл использовать встроенные в jQuery функции запроса, такие как $.get, если вы хотите использовать fetch без изменения кода, один из вариантов - просто включить polyfill для fetch: добавить следующее

<script src="https://cdn.polyfill.io/v2/polyfill.js?features=fetch"></script>

(или какой-либо другой скрипт polyfill, который включает Fetch) в ваш HTML.

0 голосов
/ 11 января 2019

fetch не поддерживается Internet Explorer.

Подробнее о том, какие браузеры его поддерживают: https://caniuse.com/#feat=fetch

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...