javascript - 如何从获取值中查找数组中的状态缩写

标签 javascript arrays var abbreviation

我正在尝试从客户端 IP 地址获取州缩写。

我使用了 IPInfo.org 的 API 从 IP 地址返回状态,效果很好,如下所示:

$.get("https://ipinfo.io", function (response) {
$state = response.region;
}, "jsonp");

我在网上看到过很多州名缩写列表( https://gist.github.com/mshafrir/2646763 ):

{
'Alabama': 'AL',
'Alaska': 'AK',
'American Samoa': 'AS',
'Arizona': 'AZ',
'Arkansas': 'AR',
'California': 'CA',
'Colorado': 'CO',
'Connecticut': 'CT',
'Delaware': 'DE',
'District Of Columbia': 'DC',
'Federated States Of Micronesia': 'FM',
'Florida': 'FL',
'Georgia': 'GA',
'Guam': 'GU',
'Hawaii': 'HI',
'Idaho': 'ID',
'Illinois': 'IL',
'Indiana': 'IN',
'Iowa': 'IA',
'Kansas': 'KS',
'Kentucky': 'KY',
'Louisiana': 'LA',
'Maine': 'ME',
'Marshall Islands': 'MH',
'Maryland': 'MD',
'Massachusetts': 'MA',
'Michigan': 'MI',
'Minnesota': 'MN',
'Mississippi': 'MS',
'Missouri': 'MO',
'Montana': 'MT',
'Nebraska': 'NE',
'Nevada': 'NV',
'New Hampshire': 'NH',
'New Jersey': 'NJ',
'New Mexico': 'NM',
'New York': 'NY',
'North Carolina': 'NC',
'North Dakota': 'ND',
'Northern Mariana Islands': 'MP',
'Ohio': 'OH',
'Oklahoma': 'OK',
'Oregon': 'OR',
'Palau': 'PW',
'Pennsylvania': 'PA',
'Puerto Rico': 'PR',
'Rhode Island': 'RI',
'South Carolina': 'SC',
'South Dakota': 'SD',
'Tennessee': 'TN',
'Texas': 'TX',
'Utah': 'UT',
'Vermont': 'VT',
'Virgin Islands': 'VI',
'Virginia': 'VA',
'Washington': 'WA',
'West Virginia': 'WV',
'Wisconsin': 'WI',
'Wyoming': 'WY'
}

但我不确定如何实际从一个函数获取输出并在此数组中使用它来输出正确的缩写。

这是如何完成的? 预先感谢您!

最佳答案

这非常简单。您可以通过两种方式访问​​ JSON 对象的属性。

  1. 使用括号表示法访问
  2. 使用点(“.”)表示法进行访问(推荐)

我创建了一个名为 getStateAbbr 的函数,它从 ipinfo.io 获取状态名称并使用括号表示法,您将获得相应的值。为什么我使用括号表示法,因为它可以有动态值。

如果您尝试. nation,那么您将得到undefined

$.get("https://ipinfo.io", function(response) {
  var state = response.region;
  getStateAbbr(state);
}, "jsonp");

var states = {
  'Alabama': 'AL',
  'Alaska': 'AK',
  'American Samoa': 'AS',
  'Arizona': 'AZ',
  'Arkansas': 'AR',
  'California': 'CA',
  'Colorado': 'CO',
  'Connecticut': 'CT',
  'Delaware': 'DE',
  'District Of Columbia': 'DC',
  'Federated States Of Micronesia': 'FM',
  'Florida': 'FL',
  'Georgia': 'GA',
  'Guam': 'GU',
  'Hawaii': 'HI',
  'Idaho': 'ID',
  'Illinois': 'IL',
  'Indiana': 'IN',
  'Iowa': 'IA',
  'Kansas': 'KS',
  'Kentucky': 'KY',
  'Louisiana': 'LA',
  'Maine': 'ME',
  'Marshall Islands': 'MH',
  'Maryland': 'MD',
  'Massachusetts': 'MA',
  'Michigan': 'MI',
  'Minnesota': 'MN',
  'Mississippi': 'MS',
  'Missouri': 'MO',
  'Montana': 'MT',
  'Nebraska': 'NE',
  'Nevada': 'NV',
  'New Hampshire': 'NH',
  'New Jersey': 'NJ',
  'New Mexico': 'NM',
  'New York': 'NY',
  'North Carolina': 'NC',
  'North Dakota': 'ND',
  'Northern Mariana Islands': 'MP',
  'Ohio': 'OH',
  'Oklahoma': 'OK',
  'Oregon': 'OR',
  'Palau': 'PW',
  'Pennsylvania': 'PA',
  'Puerto Rico': 'PR',
  'Rhode Island': 'RI',
  'South Carolina': 'SC',
  'South Dakota': 'SD',
  'Tennessee': 'TN',
  'Texas': 'TX',
  'Utah': 'UT',
  'Vermont': 'VT',
  'Virgin Islands': 'VI',
  'Virginia': 'VA',
  'Washington': 'WA',
  'West Virginia': 'WV',
  'Wisconsin': 'WI',
  'Wyoming': 'WY'
}

function getStateAbbr(name) {
  alert(states[name]);
}
<script src="https://code.jquery.com/jquery-3.1.0.js"></script>

关于javascript - 如何从获取值中查找数组中的状态缩写,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42606444/

相关文章:

javascript - Phonegap/Cordova - cdvfile ://localhost in terms of the app root? 在哪里

javascript - 将按钮添加到 tinymce

Javascript:单击元素一百万次的最快方法是什么

c++ - 按字母顺序排列名称

javascript - 在标记弹出窗口上显示自定义内容的功能

c - 在 C 中将 var 赋值给 var

Javascript 替换在应该起作用的时候却不起作用

javascript - 每次调用 onclick 函数时显示不同的文本

python - 如何使用给定大小的数组实现网格?

c# - 在 for 循环中制作 var