首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >电子邮件表单应用: NodeJs + Express -无法获取/

电子邮件表单应用: NodeJs + Express -无法获取/
EN

Stack Overflow用户
提问于 2021-11-23 01:41:40
回答 1查看 30关注 0票数 0

每当我在使用VS Code的实时服务器上运行我的应用程序时,我都会收到这个无法获取错误的信息。我最好的猜测是,这与我的路由错误有关,我只是不确定我的路由错误在哪里。感谢任何形式的帮助<3

目标是在应用程序完成时发送一个POST请求,并将用户的电子邮件输入到表单元素中。

app.js

代码语言:javascript
复制
const express = require('express');
const request = require('request');
const bodyParser = require('body-parser');
const path = require('path');

const app = express();

//Middleware
app.use(express.json());

app.use(bodyParser.urlencoded({extended: false}));

console.log("The directory is:", (path.join(__dirname, '/site')));

app.use(express.static(path.join(__dirname, '/site')));

app.post('/', (req, res) => {
    console.log('hey!');
});

app.listen(5000, console.log('Server started!'))

landing.html

代码语言:javascript
复制
<form action="/subscribe" method="POST">
  <div class="newsletter-form-grp">
     <i class="far fa-envelope"></i>
    <input name="email" id="email" required pattern="[a-z0-9.%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$" type="email" placeholder="Enter your email...">
  </div>
  <button id="cta">SUBSCRIBE <i class="fas fa-paper-plane"></i></button>
</form>

landing.html中的JS代码

代码语言:javascript
复制
<script>
   //form submission
   let cta = document.getElementById('cta');
   let email = document.getElementById('email').value;
   let status = document.getElementById('status');

   cta.addEventListener('click', (event) => {
       event.preventDefault();

       if(this.email.value == null || this.email.value == "") {
             status.classList.add('statusShow');
       } else {
              let fetchData = {
                 method: 'POST',
                 body: JSON.stringify({email: this.email.value, js: true}),
                 headers: {"Content-Type": "application/json"}
              }

              fetch('/subscribe', fetchData)
                 .then(res => {
                   if(res.ok) {
                                // yay
                   } else {
                      status.classList.add('statusShow');
                   }
                })
       }
    });
</script>

JSON包

代码语言:javascript
复制
{
  "name": "Main",
  "version": "1.0.0",
  "description": "",
  "main": "site/js/app.js",
  "dependencies": {
    "body-parser": "^1.19.0",
    "express": "^4.17.1",
    "index": "^0.4.0",
    "request": "^2.88.2"
  },
  "devDependencies": {
    "nodemon": "^2.0.15"
  },
  "scripts": {
    "serve": "node app",
    "dev": "nodemon app"
  },
  "keywords": [],
  "author": "",
  "license": "ISC"
}

项目树:https://imgur.com/a/B9Ucrap

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-23 03:03:22

您的landing.html是一个静态文件(在site文件夹中?),而且您也没有在Express中定义GET路由来提供此页面。因此,为了从浏览器访问它,您需要使用:http://localhost:5000/landing.html

您的表单显示为:<form action='/subscribe' action='POST'>。因此,您的Express需要定义以下路由:

代码语言:javascript
复制
app.post("/subscribe", (req, res) => {
   console.log("hey!");
   res.send("got it!"); 
});

顺便说一句,您的Html没有idstatus的元素。您的订阅按钮单击事件代码将命中错误。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70074413

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档