В настоящее время я работаю над обратным геокодированием.Я использую пример, который я нашел в документации mapbox.Моя схема выглядит так:
const mongoose = require("mongoose");
const PostSchema = new mongoose.Schema({
title: {
type: String,
required: [true, "empty field"]
},
description: {
type: String,
required: [true, "empty field"]
},
images: [String],
coordinates: Array,
comments: [
{
type: mongoose.Schema.Types.ObjectId,
ref: "Comment"
}
],
date: { type: Date, default: Date.now },
views: { type: Number, default: 0 }
});
module.exports = mongoose.model("Post", PostSchema);
Затем я пытаюсь получить местоположение из полей ввода
<% include ../partials/header %>
<div class="container">
<div class="row">
<div class="col-md-6">
<form action="/blog" method="post" enctype="multipart/form-data">
<div class="form-group">
<label for="title-text">Title:</label>
<input
id="title-text"
type="text"
name="title"
class="form-control"
placeholder="title"
/>
</div>
<div class="form-group">
<label for="description-text">Description:</label>
<textarea
id="description-text"
class="form-control"
name="description"
id="textField"
cols="30"
rows="10"
placeholder="description"
></textarea>
</div>
<div class="form-group">
<label for="location-text">Address:</label>
<input
id="location-text geocoder"
class="form-control geocoder"
type="text"
name="address"
placeholder="1234 Main St"
/>
</div>
<div class="form-row">
<div class="from-group col-md-6">
<label for="inputCity">City</label>
<input type="text" name='city' class="form-control" id="inputCity">
</div>
<div class="form-group col-md-4">
<label for="inputState">State</label>
<select id="inputState" name='region' class="form-control">
<option selected>Choose...</option>
<option value="AL">Alabama</option>
<option value="AK">Alaska</option>
<option value="AZ">Arizona</option>
<option value="AR">Arkansas</option>
<option value="CA">California</option>
<option value="CO">Colorado</option>
<option value="CT">Connecticut</option>
<option value="DE">Delaware</option>
<option value="FL">Florida</option>
<option value="GA">Georgia</option>
<option value="HI">Hawaii</option>
<option value="ID">Idaho</option>
<option value="IL">Illinois</option>
<option value="IN">Indiana</option>
<option value="IA">Iowa</option>
<option value="KS">Kansas</option>
<option value="KY">Kentucky</option>
<option value="LA">Louisiana</option>
<option value="ME">Maine</option>
<option value="MD">Maryland</option>
<option value="MA">Massachusetts</option>
<option value="MI">Michigan</option>
<option value="MN">Minnesota</option>
<option value="MS">Mississippi</option>
<option value="MO">Missouri</option>
<option value="MT">Montana</option>
<option value="NE">Nebraska</option>
<option value="NV">Nevada</option>
<option value="NH">New Hampshire</option>
<option value="NJ">New Jersey</option>
<option value="NM">New Mexico</option>
<option value="NY">New York</option>
<option value="NC">North Carolina</option>
<option value="ND">North Dakota</option>
<option value="OH">Ohio</option>
<option value="OK">Oklahoma</option>
<option value="OR">Oregon</option>
<option value="PA">Pennsylvania</option>
<option value="RI">Rhode Island</option>
<option value="SC">South Carolina</option>
<option value="SD">South Dakota</option>
<option value="TN">Tennessee</option>
<option value="TX">Texas</option>
<option value="UT">Utah</option>
<option value="VT">Vermont</option>
<option value="VA">Virginia</option>
<option value="WA">Washington</option>
<option value="WV">West Virginia</option>
<option value="WI">Wisconsin</option>
<option value="WY">Wyoming</option>
<option value="">-- CANADA --</option>
<option value="AB">Alberta</option>
<option value="BC">British Columbia</option>
<option value="MB">Manitoba</option>
<option value="NB">New Brunswick</option>
<option value="NF">Newfoundland and Labrador</option>
<option value="NT">Northwest Territories</option>
<option value="NS">Nova Scotia</option>
<option value="NU">Nunavut</option>
<option value="ON">Ontario</option>
<option value="PE">Prince Edward Island</option>
<option value="PQ">Quebec</option>
<option value="SK">Saskatchewan</option>
<option value="YT">Yukon Territory</option>
</select>
</div>
<div class="form-group col-md-2">
<label for="inputZip">Zip</label>
<input type="text" name='zip_code'class="form-control" id="inputZip">
</div>
</div>
<div class="form-group input-file-container">
<label for="my-file" class="input-file-trigger" tabindex="0"
>Select a images...</label
>
<input
id="my-file"
class="form-control-file input-file"
type="file"
name="images"
multiple="multiple"
required
/>
</div>
<div class="form-group">
<button class="btn btn-lg btn-primary btn-block" >Submit</button>
</div>
</form>
</div>
</div>
</div>
<a href="/blog">back...</a>
<% include ../partials/footer %>
</div>
Мой код на бэкэнде выглядит так:
let title = req.body.title;
let description = req.body.description;
let content = req.body.content;
let address = req.body.address;
let city = req.body.city;
let zip = req.body.zip_code;
let region = req.body.region;
geocodingClient
.reverseGeocode{
query: [address, city, zip, region],
limit: 10
})
.send()
.then(response => {
const match = response.body;
const coordinates = match.features[0].geometry.coordinates;
const newPost = {
title: title,
description: description,
content: content,
images: images,
coordinates: coordinates
};
Post.create(newPost)
.then(newCreatedPost => {
if (newCreatedPost) {
res.redirect("/blog");
console.log(newPost.coordinates);
} else {
res.send("where is the post");
}
})
.catch(err => {
// req.flash("error", err.message);
// res.redirect("/blog/new");
console.error(err.message);
});
});
}
Когда он пытается создать новое сообщение, он получает эту ошибку:
Error: query must be a string.
Кто-нибудь уже сталкивался с такой проблемой и знает, как ее решить.Буду благодарен за каждый намек