javascript - 如何从 html 表单更改 geojson 搜索参数
问题描述
我使用数据库中的 php 制作了 geojson 文件,但我需要能够使用主页中的表单更改查询参数,这是表单和加载的 json 文件:
<script src="js/jquery-3.3.1.min.js" type="text/javascript"></script>
<div class="form">
<form method="get">
<input type="text" name="number" id="number" placeholder="to" >
<input type="text" name="startDate" id="sDate" placeholder="From" >
<input type="text" name="endDate" id="eDate" placeholder="till"><br/>
<input type="submit" name="Search" id="Search" value="Search">
</form>
</div>
<script>
var geoJsonData = $.ajax({
url: "json2.php",
dataType: "json",
success: console.log("succes"),
error: function (xhr) {
alert("Json error")
}
})
</script>
这是来自geojson文件(json2.php)的查询:
$number = $_GET['number'];
$startD = date('d.m.Y');
$endD = date('d.m.Y');
$startData = strtotime($startD . '00:00:00');
$pgsqlstartdata = date('Y-m-d H:i:s', $startData);
$endData = strtotime($endD . '23:59:59');
$pgsqlenddata = date('Y-m-d H:i:s', $endData);
$query = pg_query($connect, "SELECT number, state, date, lat,long "
. "FROM schema.table "
. "WHERE number = '$number' AND "
. "data BETWEEN '$pgsqlstartdata' and '$pgsqlenddata' order by data asc limit 100 ");
当我尝试将 json 文件包含到表单文件中时,它给了我 parese 错误,因为表单不是 json 格式,所以任何人都知道如何发送参数?
解决方案
我不确定你想要完成什么,但如果目标是将表单作为 json 传递给 PHP,那么你需要使用 serialize() 函数。此外,您当前没有通过 AJAX 调用传递任何数据。让我们解决这个问题。
首先,将表单方法更改为 post 并在表单中添加一个 id,以便我们可以直接访问它:
<form method="post" id="geoform">
接下来,更改 AJAX 调用中的第一行:
var geoJsonData = $.ajax({
url: "json2.php",
dataType: "json",
type: "post",
data: $("#geoform").serialize(),
最后,在 PHP 中反序列化并输出表单,这样您就可以看到正在使用的内容:
<?php
$formData = json_decode($_POST);
var_dump($formData);
推荐阅读
- actionscript-3 - ActionScript 3.0 - 不同电影剪辑之间的冲突
- azure - 为什么这个 Azure SQL 查询非常慢?
- java - 将 ArrayList 同步为静态方法参数
- java - 面板的工具提示
- postgresql - Postgres:选择具有多个唯一第二列的重复项
- visual-studio-2015 - 无法选择 .Net 版本并在 Visual Studio 2015 中创建项目
- php - 会话在本地主机上混淆了......?
- javascript - 如何使用 AJAX 将所有选中的项目发送到 php
- scala - Intellij:如何从上一行的开头缩进下一行的 2 个空格?
- stata - 在 Stata 中汇集和保存多个估算数据的简单技术