Использование Promise в методе GET для получения данных - PullRequest
0 голосов
/ 29 апреля 2020

У меня есть код ниже, чтобы получить данные из URL (пример). Я могу получить данные в Chrome нормально, но в Microsoft Edge я не могу. Как я могу заставить это работать для Edge?

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <title>Bootstrap Example</title>
      <meta charset="utf-8">
      <meta name="viewport" content="width=device-width, initial-scale=1">
      <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css">
      <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
      <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/js/bootstrap.min.js"></script>
    </head>
    <body>
    <div class="form-group">
         <div class="col-sm-4">
              <select id="dropdown" name="dropdown" class="form-control">
              </select>
         </div>
    </div>
<script >
    function requestData() {

        var promise = new Promise(function(resolve, reject) {
            let url = 'https://api.website.example';
            let req = new Request(url, {
                method: 'GET',
                headers: {
                    "my-api-key": "MyAPIkeyCode"
                }
            });

            //fetch JSON Data and write it into console
            fetch(req)
                .then(async r => resolve(await r.text()))
                .catch(e => console.error('error...' + e));

        });

        return promise;

    }

requestData()
    .then(function(response) {
        var strInnerHTML = "";
        $.each(JSON.parse(response), function(index, value) {
            strInnerHTML += '<option value="' + index + '">' + value + '</option>';
        });

        var firstIndex = '<option selected="true" disabled>Please Select</option>'

        document.getElementById('dropdown').innerHTML = firstIndex + strInnerHTML;


    })

</script>

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