#javascript #html #function #button
Вопрос:
У меня есть файл JavaScript с функцией «AddCenter(e)», которая вызывается одним нажатием кнопки, но ничего не происходит. Кто-нибудь может мне помочь?
Для получения более подробной информации я использую node.js проект, экспресс-сервер и онлайн-среда разработки под названием: Replit. Вот URL-адрес веб-сайта: replit.com
РЕДАКТИРОВАТЬ : Итак, я изменил все, как вы, ребята, предлагали, но по-прежнему ничего не происходит.
Вот ссылка на часть веб-сайта : Ссылка на веб-сайт
Таким образом, URL-адрес должен измениться с : https://worldsportcenters.xxgamecodingxx.repl.co/api/v1/im чтобы : https://worldsportcenters.xxgamecodingxx.repl.co/
Но вместо этого он переходит на тот же URL-адрес, но добавляет ? в конце : https://worldsportcenters.xxgamecodingxx.repl.co/api/v1/im?
Кто-нибудь знает, почему ???
Вот мой файл JavaScript :
const centers = require('../../models/Center');
const centerName = document.getElementById('center-name');
const centerAddress = document.getElementById('center-address');
const centerDescription = document.getElementById('center-description');
const key = document.getElementById('dev-key');
const submitButton = document.getElementById('submit-button');
function CheckForURL(str)
{
let reg = new RegExp('([a-zA-Zd] ://)?((w :w @)?([a-zA-Zd.-] .[A-Za-z]{2,4})(:d )?(/.*)?)', 'i')
return reg.test(str)
}
async function AddCenter(e)
{
e.preventDefault();
if (centerName.value === '') return alert('Please fill in the "Sport Center Name" field');
else if (centerAddress.value === '') return alert('Please fill in the "Sport Center Address" field');
else if (centerDescription.value === '') return alert('Please fill in the "Sport Center Description" field');
else if (key.value === '') return alert('Please fill in the "Developper Key" field');
else if (CheckForURL(centerDescription.value)) return alert('You can not put a url in the free marker "Sport Center Description" field');
else if (key.value !== process.env['DEVELOPER_KEY'])
{
alert('You filled in the wrong KEY in the "Sport Center Description" field, and this window will self destruct in 10 seconds');
var timer = setInterval(function() {
window.close();
}, 10000);
return;
}
centers.create({
type: 'informative',
name: centerName.value,
address: centerAddress.value,
description: centerDescription.value
});
if (res.status === 400)
{
throw Error('That sport center already exists !');
}
alert('Center added !');
window.location.href = '/';
}
submitButton.addEventListener("click", function ()
{
AddCenter();
});
HTML-файл :
<!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" />
<link
rel="stylesheet",
href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css",
integrity="sha384-ggOyR0iXCbMQv3Xipma34MD dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T",
crossorigin="anonymous"
/>
<title>World Sport Center - Add Center</title>
<link rel="stylesheet" href="/css/main.css" />
</head>
<body>
<div class="text-center">
<div class="container my-3">
<h1 class="display-4 text-center disable-select">Add Informative Marker</h1>
<form id="center-form" class="mb-4">
<div class="form-group">
<blockquote class="blockquote">
<p class="mb-0 disable-select">Sport Center Name</p>
</blockquote>
<input type="text" id="center-name" class="form-control" />
</div>
<div class="form-group">
<blockquote class="blockquote">
<p class="mb-0 disable-select">Sport Center Address</p>
</blockquote>
<input type="text" id="center-address" class="form-control" />
</div>
<div class="form-group">
<blockquote class="blockquote">
<p class="mb-0 disable-select">Sport Center Description</p>
</blockquote>
<textarea type="text" rows="2" id="center-description" class="form-control" maxlength="150"></textarea>
</div>
<div class="form-group">
<blockquote class="blockquote">
<p class="mb-0 disable-select">Developper Key</p>
</blockquote>
<input type="text" id="dev-key" class="form-control" />
</div>
<a href="/api/v1/add" class="btn btn-outline-primary btn-lg"><-- Back</a>
<button id="submit-button" class="btn btn-lg btn-primary">Submit --></button>
</form>
</div>
</div>
<script src="/js/informative.js"></script>
</body>
</html>
Комментарии:
1.
setInterval(function() { window.close(); }, 1000)
каждую секунду пытается закрыть окно. Я бы подумал, что было бы достаточноsetTimeout
сделать это один раз, так как, как только окно закроется, интервал больше не будет выполняться.
Ответ №1:
onclick=»Добавить центр»
Значение onclick
атрибута является телом функции для обработчика событий.
Это делает это, примерно, эквивалентным:
theElement.addEventListener("click", function () {
AddCenter;
});
Если вы хотите вызвать функцию, вам нужно сделать это с (
любыми аргументами, которые вы хотите передать, затем )
.
Тем не менее, использование addEventListener
внутренних атрибутов событий имеет некоторые недостатки и не очень хорошо разделяет проблемы.