gpt4 book ai didi

javascript - Fusion Tables 层 URL 请求限制(2048 个字符)

转载 作者:搜寻专家 更新时间:2023-11-01 05:30:02 25 4
gpt4 key购买 nike

我正在使用 Google map 突出显示一些使用 Fusion Tables 获取几何图形的国家/地区。你可以在这里看到一个例子:

http://jsfiddle.net/4mtyu/689/

var layer = new google.maps.FusionTablesLayer({
query: {
select: locationColumn,
from: tableId,
where: "ISO_2DIGIT IN ('AF','AL','DZ','AD','AO','AG','AR','AM','AU','AT','AZ','BS','BH','BD','BB','BY','BE','BZ','BJ','BT','BO','BA','BW','BR','BN','BG','BF','BI','KH','CM','CA','CV','CF','TD','CL','CN','CO','KM','CG','CD','CR','HR','CU','CY','CZ','DK','DJ','DM','DO','EC','EG','SV','GQ','ER','EE','ET','FJ','FI','FR','GA','GM','GE','DE','GH','GR','GD','GT','GN','GW','GY','HT','HN','HU','IS','IN','ID','CI','IR','IQ','IE','IL')"
},
options : {suppressInfoWindows:true},
styles: [{
polygonOptions: {
fillColor: "#000000",
strokeWeight: "0",
fillOpacity: 0.4
}
}]
});

当我试图从 table 上抓取太多元素时,问题就开始了。 Google 使用包含所有查询值的 URL 来获取所需的数据,并且通过 URL 编码,它的长度可能会变得非常大。

如果您打开控制台并检查错误中抛出的 URL,您可以在此处看到 URL 示例:

http://jsfiddle.net/4mtyu/690/

它在该特定示例中生成的 URL 是 3749 个字符,远远超过了 2048 个字符的限制。

有没有人有任何想法可以防止 URL 变得这么大,但同时仍然能够选择 150 多个项目?

最佳答案

最简单的解决方案是将事物移动到客户端: http://jsfiddle.net/4mtyu/725/


第 1 部分:初始化 map 和融合表

您可以随心所欲地执行此操作,只需确保融合表已选择所有国家/地区。示例:

function initialize() {
//settings
var myOptions = {
zoom: 2,
center: new google.maps.LatLng(10, 0),
mapTypeId: google.maps.MapTypeId.ROADMAP
};
//get map div
map = new google.maps.Map(document.getElementById('map_div'),
myOptions);

// Initialize padded JSON request
var script = document.createElement('script');
var url = ['https://www.googleapis.com/fusiontables/v1/query?'];
url.push('sql=');

//select all the countries!!
var query = 'SELECT name, kml_4326 FROM ' +
'1foc3xO9DyfSIF6ofvN0kp2bxSfSeKog5FbdWdQ';
var encodedQuery = encodeURIComponent(query);

//generate URL
url.push(encodedQuery);
url.push('&callback=drawMap');//Callback
url.push('&key=AIzaSyAm9yWCV7JPCTHCJut8whOjARd7pwROFDQ');//select all countries
script.src = url.join('');

//Add Script to document
var body = document.getElementsByTagName('body')[0];
body.appendChild(script);
}

第 2 部分:对国家进行排序并呈现

  • (a) 获得完整的国家/地区列表后,您必须对它们进行排序。一个简单的 indexOf 检查应该可以解决问题。

  • (b) 排序后我们需要将我们的国家转换为 LatLon 坐标,这是在 constructNewCoordinates 函数中完成的(见下文)

  • (c) 然后剩下的就是生成多边形并将其添加到我们的 map 中!

例子:

var countries = [...];

//This is the callback from the above function
function drawMap(data) {
//Get the countries
var rows = data['rows'];


for (var i in rows) {
// (a) //
//If the country matches our filled countries array
if (countries.indexOf(rows[i][0]) !== -1)

var newCoordinates = [];

// (b) //
// Generate geometries and
// Check for multi geometry countries
var geometries = rows[i][1]['geometries'];
if (geometries) {
for (var j in geometries) {
//Calls our render function, returns Polygon Coordinates (see last step);
newCoordinates.push(constructNewCoordinates(geometries[j]));
}
} else {
//Calls our render function, returns Polygon Coordinates (see last step);
newCoordinates = constructNewCoordinates(rows[i][1]['geometry']);
}

// (c) //
//Generate Polygon
var country = new google.maps.Polygon({
paths: newCoordinates,
strokeWeight: 0,
fillColor: '#000000',
fillOpacity: 0.3
});


//add polygon to map
country.setMap(map);
}
}
}
}

第 3 部分:生成坐标

// (b) //
function constructNewCoordinates(polygon) {
var newCoordinates = [];
var coordinates = polygon['coordinates'][0];
for (var i in coordinates) {
newCoordinates.push(
new google.maps.LatLng(coordinates[i][1], coordinates[i][0]));
}
return newCoordinates;
}

关于javascript - Fusion Tables 层 URL 请求限制(2048 个字符),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32982940/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com