javascript - 自动检测位置(城市和州),并将该信息分别放入输入和选择字段中

标签 javascript jquery search geolocation

我一直在研究 Geolocation API 以及 jQuery Geolocation API,但尚未找到适合我正在尝试做的事情的良好解决方案。

最终,我希望用户能够单击城市位置输入中的图标,浏览器检测他们的城市和州,然后该信息自动填充到字段中,城市字段是基本输入,状态是一个选择。

<div class="search">
  <a href="autodetect-here"><span class="fa fa-map-marker"></span></a>
  <input type="text" id="location" placeholder="City" />
  <select>

<option selected="state">State</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="DC">District Of Columbia</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>

最佳答案

使用 HTML5 地理定位 API 获取经度和纬度,然后将这些坐标发送到 API,例如 Google 的地理编码 API。这将返回一个地址,您可以从中解析城市和州。

HTML5 Geolocation

Google geocoding API

Note: As of Chrome 50, the Geolocation API will only work on secure contexts such as HTTPS. If your site is hosted on an non-secure origin (such as HTTP) the requests to get the users location will no longer function.

关于javascript - 自动检测位置(城市和州),并将该信息分别放入输入和选择字段中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44762199/

相关文章:

objective-c - 在 NSString 搜索栏中不断搜索子字符串

javascript - 如何按照请求的顺序将异步响应推送到数组中?

jquery - 使用 Jquery 访问特定行

JQuery:查找/过滤上下文中的属性

jquery - 表单展开时移动 DIV(过渡 CSS)

search - 我可以保护短单词免受 Solr 中 n-gram 过滤器的影响吗?

javascript - 搜索建议 html 输入

javascript - 在 Sequelize 中模拟

javascript - 如何在更改文件时保持 html 文件状态相同

javascript - Python 使用 beautifulsoup 解析 Javascript