如何在单击按钮时刷新Web用户控件

本文关键字:刷新 Web 用户 控件 按钮 单击 | 更新日期: 2023-09-27 18:24:44

我在aspx页面上使用web用户控件来显示谷歌地图上的位置,我将位置作为aspx页面加载事件的参数传递到该地图中,无论何时加载页面,我都能完美地获得位置。

每当用户点击ASPX页面上的"搜索"按钮搜索特定位置时,我必须更改位置,并且我在"搜索"按键点击事件中将位置传递给web用户控件,但无法将位置获取到web用户控件上。

public partial class MapControl : System.Web.UI.UserControl
{
    public List<string> MyLocation {get; set; }
    protected void Page_Load(object sender, EventArgs e)
    {
        GeoCode geocode;
        List<GMarker> markers = new List<GMarker>();
        for (int i = 0; i < MyLocation.Count(); i++)
        {
            geocode = GMap1.getGeoCodeRequest(MyLocation[i]);
            GLatLng gLatLng = new GLatLng(geocode.Placemark.coordinates.lat, geocode.Placemark.coordinates.lng);
            GMap1.setCenter(gLatLng, 20, GMapType.GTypes.Normal);
            GMarker oMarker = new GMarker(gLatLng);
            markers.Add(oMarker);
            //GMap1.Add(oMarker);
            GListener listener = new GListener(oMarker.ID, GListener.Event.click, string.Format(@"function () {{ var w = new google.maps.InfoWindow(); w.setContent('<center>{0}</center>'); w.open({1}, {2});}}", "<b>" + MyLocation[i] + "</b>", GMap1.GMap_Id, oMarker.ID));
            GMap1.Add(listener);
        }
        GMap1.Add(new GMapUI());
        GMap1.GZoom = 10;
 protected void Button1_Click1(object sender, EventArgs e)
    {
 List<string> locations = new List<string>();
                for (int i = 0; i < ListView1.Items.Count; i++)
                {
                    Label addressline1 = (Label)this.ListView1.Items[i].FindControl("addr1");
                    string addrloc = addressline1.Text;
                    locations.Add(addrloc);
                }
                MapControl mc = LoadControl("~/MapControl.ascx") as MapControl;
                mc.MyLocation = locations;
}

我将此web用户控件包含在Search.aspx文件中,当我从页面加载事件中传递位置时,它是有效的,但当我试图从搜索按钮单击事件中将Null值传递到web用户控件的Mylocations值时,该值为Null。。那么有没有办法用更新的位置重新加载用户控件。

如何在单击按钮时刷新Web用户控件

我认为您可以使用这里的updatepanel。你必须将谷歌地图保持在更新面板中,并将此按钮的触发器设置为你的地图。然后我想你会得到你想要的。如果有任何困惑,请让我知道