无法让Update面板正常工作

时间:2012-09-10 11:54:18

标签: javascript asp.net google-maps-api-3 updatepanel reload

我正在使用Google地图apiv3在网站上工作。我在更新面板中有一个按钮,通过它我可以使用button_click和javascript函数后面的代码执行一些逻辑。

由于按钮位于更新面板中,我无法在firebug的监视窗口中看到任何内容,并且我的javascript函数中的断点都不起作用。没有更新面板,我可以看到手表中的执行流程,一切正常,但我在地图上重新加载。

aspx中的代码:

    <asp:ScriptManager ID="ScriptManager1" runat="server"> </asp:ScriptManager>
    <asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional">
        <ContentTemplate>
            <asp:Button ID="Button1" runat="server" style="z-index: 1; left: 573px; top: 146px; position: absolute" Text="Show route" onclick="Button1_Click1"/>
        </ContentTemplate>
        <Triggers>
            <asp:AsyncPostBackTrigger ControlID="Button1" EventName="Click"/>
        </Triggers>
    </asp:UpdatePanel>

Button_Click1:

protected void Button1_Click1(object sender, EventArgs e)
{
    using (con = new MySqlConnection("server=localhost; uid=root;password=as64ws;database=Gmaps"))
    da = new MySqlDataAdapter("select * from routes where uid='a1'", con);
    da.Fill(ds, "mroute");
    foreach (DataRow r in ds.Tables[0].Rows)
    {
        uroute.Add(r["latlng"].ToString());
    }
    croute = new string[uroute.Count];
    croute = uroute.ToArray();
    hdncroute.Value = string.Join("&", croute);
    ScriptManager.RegisterClientScriptBlock(this, typeof(Button), "routes", "droute()", true);
}

使用Javascript:

function droute()
{
    var route=[];
    var temp;
    temp = document.getElementById('<%= hdncroute.ClientID %>').value;
    route= temp.split('&');
    //Loop to add locations and draw line
    var path= polyline.getPath();
    for(var i=0;i<route.length;i++)
        {
            var input= route[i];
            var ltln = input.split(",",2);
            var lat=parseFloat(ltln[0]);
            var lng=parseFloat(ltln[1]);
            var pos= new google.maps.LatLng(lat,lng);
            var marker= new google.maps.Marker({position:pos,map:map});
            path.push(route[i]);
            google.maps.event.addListener(marker,'click',showiwindow);
        }
    function showiwindow(event)
    {
    iwindow.setContent("<b>Coordinates are:</b><br/>Latitude:"+event.latLng.lat()+"<br/>Longitude:"+event.latLng.lng());
    iwindow.open(map,this);
    } 
}

我无法获取要在地图上显示的值。 我应该将按钮放在更新面板中还是放在更新面板中的地图上?我哪里出错?

2 个答案:

答案 0 :(得分:1)

我会废弃你的逻辑的很大一部分。

我会按下按钮点击你的代码隐藏中的一个jquery ajax帖子到一个webservice,它会将一个数组返回到你的ajax帖子,然后在你的ajax帖子的成功部分我会触发你的javascript例程。

http://dotnetguts.blogspot.com/2012/01/jquery-ajax-examples-by-calling-aspnet.html

我上面描述的是我几乎所有的谷歌地图调用.......我还没有看到一个更合适的方式在我读过的近百页的网页上这样做学科。如果您需要了解更多关于如何这样做的信息,请告诉我。

这是另一个描述如何执行jquery ajax帖子的好页面。 :

Call code behind method from Jquery

答案 1 :(得分:0)

设置UpdateMode =“Conditional”并将Button设置为AsynPostBacktrigger。可能会解决问题。