我正处于使用java脚本的初始阶段,我在asp.net中编写了一个小应用程序,用于使用Google Maps APIv3。我想在面板中显示地图。这是我写的代码,但我在将java脚本与Panel的OnLoad事件绑定时遇到问题:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>Map Test</title>
<style type="text/css">
html{height:100%}
body{height:100%; margin:0;padding:0}
#map_can{height:100%}
</style>
<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?key=AIzawerwerQ55N500rxxxxdPNvMoQ74aRYO30Wo&sensor=true">
</script>
<script type="text/javascript">
function init()
{
var mapoptions=
{
center: new google.maps.LatLng(17.379064211298, 78.478946685791),
zoom:8,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map=new google.maps.Map(document.getElementById("map_can"),mapoptions);
}
</script>
</head>
<body>
<form id="form1" runat="server">
<asp:Panel OnLoad="init()" ID="Panel1" runat="server"
style="z-index: 1; left: 37px; top: 59px; position: absolute; height: 273px; width: 565px">
<div id="map_can" style="width:100%; height:100%"></div>
</asp:Panel>
</form>
</body>
</html>
错误:ASP.default_aspx' does not contain a definition for 'init'
我想我绑错了方法。建议请。
答案 0 :(得分:1)
Panel OnLoad
属性用于为Load事件设置服务器端处理程序(它应该是页面类中的方法)。
无法在Panel控件上设置客户端加载事件,因为它会生成DIV元素(并且DIV元素不支持加载事件)。
一种原始的方法是使用BODY元素的客户端加载事件:
<body onload="init();" >
...
</body>
但更好的方法是等待DOM就绪以调用函数。一种简单且跨浏览器的方式是使用像jQuery这样的库:
<script type="text/javascript">
$(document).ready(function() {
var mapoptions = {
center: new google.maps.LatLng(17.379064211298, 78.478946685791),
zoom: 8,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById("map_can"),mapoptions);
});
</script>