0
   $(document).ready(function ()
    {
        $(".viewmap").click(function ()
        {
            var id = $(this).attr("id");
            var responseURL = "~/changemap?id=" + id;
            //alert(responseURL);
            $.ajax(
            {
                url: responseURL,
                dataType: "json",
                type:"GET",
                success: function (dt)
                {
                    initialize(dt.Latt, dt.Longt); 
                }
            }
            );
        }
        );
    });

changemap.cshtml我使用该脚本对执行以下操作的页面进行 ajax 调用

@{

    if(!IsPost)
    {
        if(!Request.QueryString["id"].IsEmpty()&&Request.QueryString["id"].IsInt())
        {
            var countryId=Request.QueryString["id"];
            var db=Database.Open("GoogleMapView");
            var dbCmd="SELECT * FROM places WHERE id=@0";
            var row=db.QuerySingle(dbCmd,countryId);
            if(null!=row)
            {
               Json.Write(row,Response.Output);
            }
        }
    }
}

即把数据库中查询到的数据以json格式返回给客户端。Initialize 函数定义为

function initialize(lat,lng)
            {
                var mapOptions = {
                    center: new google.maps.LatLng(lat,lng),zoom: 8,mapTypeId: google.maps.MapTypeId.ROADMAP 
                };
                var map = new google.maps.Map(document.getElementById("gmap"),mapOptions);
            }

但是当我点击 class 的 div 标签时viewmap,什么也没有发生。我想我想念更多的脚本来让我的应用程序正常工作。

我只尝试实现一个简单的谷歌地图视图,其中一旦用户单击地名作为超链接,将重新加载与其匹配的地图。

4

2 回答 2

0

尝试以下

            success(data){

                   initialize(data.d.Latt, data.d.Longt); 



              }

有关为什么使用 d 的更多参考,请查看以下链接

      http://encosia.com/never-worry-about-asp-net-ajaxs-d-again/
于 2012-09-23T07:40:33.233 回答
0

我认为

var responseURL = "~/changemap?id=" + id;

应该

var responseURL = '@(Url.Content("~/changemap")+"?id=")' + id;
于 2012-09-23T07:29:54.513 回答