繁体   English   中英

在 html 页面上显示 api 响应

[英]displaying api response on html page

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <meta http-equiv="X-UA-Compatible" content="ie=edge">
   <title>JSON Test</title>
</head>
<body>
   <h1>Hello World</h1>
   <div id="myData"></div>
   <script>
       fetch('http://localhost:3000/api/product/1234567')
           .then(function (response) {
               return response.json();
           })
           .then(function (data) {
               appendData(data);
           })
           .catch(function (err) {
               console.log('error: ' + err);
           });
       function appendData(data) {
           console.log(data)
           var mainContainer = document.getElementById("myData");
           for (let key in data) {
               var div = document.createElement("div");
               div.innerHTML = 'name: ' + data[key] + 'label' + data[key];
               mainContainer.appendChild(div);
           }
       }
   </script>
</body>
</html>

尝试获取 json 响应并将其显示在 html 页面上。 它给了我一个错误:SyntaxError: Unexpected end of JSON input。 我想我在这里可能会获得一些关于如何解决这个问题以及为什么会发生这种情况的帮助。 谢谢你。

编辑:

我在控制台上得到的响应:

{ 产品:1234567,名称:'TV',salePrice:149.99 }

主要原因是您的响应不是 JSON 格式,这可能是因为获得了一些非 json 格式的响应。 请发布示例 JSON 响应格式以更好地理解。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM