为了账号安全,请及时绑定邮箱和手机立即绑定

未兑现承诺

未兑现承诺

温温酱 2022-07-27 21:00:44
所以我对 JavaScript 还很陌生,我有一个充满名词的文本文档,并认为用这些名词创建 api 的好方法。我阅读了文件并将它们添加到列表中public List<Noun> getData() throws IOException {    Scanner sc = new Scanner(new     File("C:\\Users\\Admin\\Desktop\\nounlist.txt"));    List<Noun> nouns = new ArrayList();    while (sc.hasNextLine()) {        nouns.add(new Noun(sc.nextLine()));    }    return nouns;}这个列表我用 Gson 转换为 Json:@GET@Path("/nouns/amount=all")@Produces(MediaType.APPLICATION_JSON)@Consumes(MediaType.APPLICATION_JSON)public Response getAllNouns() throws IOException {          return Response.ok().entity(gson.toJson(nf.getData())).build();}然后我开始用 js 创建我的前端并尝试获取数据,但遇到了一个问题,说 uncaught in promise, type error, nouns.forEach is not a functionimport "bootstrap/dist/css/bootstrap.css";const root = document.getElementById("root");var url = "http://localhost:8084/CORSJavaJax-rs/api/noun/nouns/amount=all";var tbody = document.getElementById("tbody");var btn = document.getElementById("btnsend");// fetch(url)//   .then(res => res.json)//   .then(nouns => {//     var n = nouns.map(noun => {//       return "<tr>" + "<td>" + noun.name + "</td>" + "</tr>";//     });//     tbody.innerHTML = n.join("");//   });btn.addEventListener("click", function() {  fetch(url)    .then(res => res.json)    .then(nouns => {      console.log(nouns);      var n = nouns.forEach(noun => {        return "<tr>" + "<td>" + noun.name + "</td>" + "</tr>";      });      tbody.innerHTML = n.join("");    });});我尝试了 map 和 forEach 但没有成功,也许我错过了一些东西,或者有些东西我只是不明白为什么我不能映射数据。
查看完整描述

1 回答

?
胡说叔叔

TA贡献1804条经验 获得超8个赞

对于您想要的,正确的用法是map调用,而不是forEach. ForEach 不返回值,它只是在集合上迭代。


您收到is not a function错误的原因很可能是由于缺少对res.json. 应该是res.json()。


btn.addEventListener("click", function() {

  fetch(url)

    .then(res => res.json())

    .then(nouns => {

      console.log(nouns);

      var n = nouns.map(noun => {

        return "<tr>" + "<td>" + noun.name + "</td>" + "</tr>";

      });

      tbody.innerHTML = n.join("");

    });

});


查看完整回答
反对 回复 2022-07-27
  • 1 回答
  • 0 关注
  • 113 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号