在页面加载时访问Javascript全局变量
本文关键字:访问 Javascript 全局变量 加载 | 更新日期: 2023-09-27 18:26:46
我正在使用代码隐藏从数据库向javascript数组添加一些元素这是代码:
protected void LoadPlaces() {
try {
DataTable dt = cs.ExecuteQry(@"SELECT location_coords from igr.locationdata ", null);
String Script = "";
foreach(DataRow dr in dt.Rows) {
string Coord = "PlacePoints=[";
bool IsNotFirst = false;
foreach(string C in dr[0].ToString().Trim().Split(''n')) {
if (IsNotFirst) Coord += ",'n";
Coord += @"new google.maps.LatLng(" + C.Trim().Split(';')[0].Split(':')[1] + "," + C.Trim().Split(';')[1].Split(':')[1] + @") ";
IsNotFirst = true;
}
Coord += "];";
Script += Coord;
//ScriptManager.RegisterStartupScript(Page, GetType(), "AddPointsToMap", Coord, true);
}
ScriptManager.RegisterClientScriptBlock(Page, GetType(), "SetMap", Script, true);
} catch (Exception ex) {
Alert(ex.Message);
}
}
我从Page_Load()调用了这个函数,但是当我试图访问map变量时,它是未定义的,我如何克服这个问题我在这个页面上添加了一个按钮,并在点击按钮时调用了上面的函数,当时javascript变量映射就可以了。Javascript代码是
map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);
AddPlace = function (Place) {
if (Place == null) return;
var mark = new google.maps.Polygon({
paths: Place,
strokeColor: '#F50',
strokeOpacity: 0.5,
strokeWeight: 2,
fillColor: '#FAA',
clickable: true,
fillOpacity: 0.7
});
mark.setMap(map);
Places.push(mark);
google.maps.event.addListener(Place, 'click', function (event) {
var vertices = this.getPath();
var strvertices = '';
for (var i = 0; i < vertices.getLength(); i++) {
strvertices.value += 'A' + i + ':' + vertices.getAt(i).lat() + ';';
strvertices.value += 'B' + i + ':' + vertices.getAt(i).lng();
strvertices.value += ''n';
}
console.Debug(strvertices);
});
}
您在哪里编写javascript代码?
在body标记的底部或表单的末尾编写javascript代码,然后这些变量就可以访问了。