Home >Web Front-end >JS Tutorial >Why Does Setting \'mode: \'no-cors\'\' Throw a SyntaxError When Using fetch?

Why Does Setting \'mode: \'no-cors\'\' Throw a SyntaxError When Using fetch?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-10-26 08:27:03674browse

Why Does Setting 'mode: 'no-cors'' Throw a SyntaxError When Using fetch?

Error When Accessing API with Fetch While Setting Mode to 'no-cors'

During an attempt to resolve a fetch promise using JavaScript, setting the mode to 'no-cors' based on a previous suggestion resulted in an error.

When the mode is set to 'cors,' it produces a CORS policy blocking error. As suggested, changing the mode to 'no-cors' with the intention of disabling CORS and fetching the resource opaquely resulted in an unexpected error:

Uncaught (in promise) SyntaxError: Unexpected end of input for return response.json()

Explanation

The root cause of this error lies in the function:

<code class="javascript">search() {
    return fetch(`${baselink}${summonerEndpoint}${summoner}${apikey}`, {mode: 'no-cors'}).then(response => {
      return response.json()
    }).then(jsonResponse => {
      console.log(jsonResponse);
      if (!jsonResponse.info) {
        return [];
      }
      return jsonResponse.info.items.map(info => ({
        id: info.id,
        accountId: info.accountId,
        name: info.name,
        profileIconId: info.profileIconId,
        revisionDate: info.revisionDate,
        summonerLevel: info.summonerLevel
      }));
    });
  }</code>

Setting the mode to 'no-cors' implies that the browser should fail silently if it encounters any CORS-related issues. In this case, the server does not grant permission using CORS and the request fails silently.

Consequently, the subsequent attempt to parse the empty response as JSON (using response.json()) throws a SyntaxError, as there is no data to parse.

Resolution

To resolve this issue, there are two main requirements:

  1. Disable 'no-cors' Mode: Remove the 'mode: 'no-cors'' from the fetch request.
  2. Enable CORS on the Server: Ensure that the server responds with the appropriate Access-Control-Allow-Origin header to grant permission to the cross-origin request.

By following these steps, the application can fetch the data successfully without experiencing any CORS-related errors.

The above is the detailed content of Why Does Setting \'mode: \'no-cors\'\' Throw a SyntaxError When Using fetch?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn