- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个更新面板。其内容包含一个 Google map 和一个多行文本框,用户可以在其中粘贴邮政编码。邮政编码在 WHERE IN (list) mysql 语句中获取并使用,以从我们的数据库返回纬度和经度。一旦数据集完成,它就会变成一个 JSON 字符串,用于创建 map 标记。
更新面板导致了问题,所以虽然我会删除它,但是在这样做时,数据集只从列表中的最后一个条目获取最后一条记录,而 JSON 数据同样只包含最后一个条目。
这是我的 ASP 代码:-
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
<table border="0px" style="width: 100%; font-family: Arial, Helvetica, sans-serif; font-size: small; color: #000000;">
<tr>
<td class="style15" valign="top">
<table border="0px" style="border: 1px solid #000000; font-family: Arial, Helvetica, sans-serif; font-size: small; color: #000000;"width="100%">
<tr>
<td align="center" class="style14" colspan="2">
<asp:TextBox ID="PostcodeListTextBox" runat="server" Height="500px"
Width="240px" TextMode="MultiLine"></asp:TextBox>
</td>
</tr>
<tr>
<td align="center" class="style14" colspan="2">
<asp:Button ID="ShowLocsButton" runat="server" Text="Show Locations" />
</td>
</tr>
</table>
</td>
<td align="center" valign="top">
<div id="mapArea" style="border:1px solid black">
</div>
<asp:Literal ID="Literal1" runat="server"></asp:Literal>
</td>
</tr>
</table>
</ContentTemplate>
</asp:UpdatePanel>
这是我的代码:-
Imports MySql.Data.MySqlClient
Imports MySql.Data
Imports System.Data
Imports System.Web
Imports System.IO
Imports System.Configuration
Imports System.Web.Script.Services
Imports System.Web.Script.Serialization
Partial Class admin_routing
Inherits System.Web.UI.Page
Dim i As Integer = 0
Dim markers As String = ""
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
End Sub
Protected Sub ShowLocsButton_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles ShowLocsButton.Click
Dim ConnString As String = ConfigurationManager.ConnectionStrings("ConnString").ConnectionString
Dim conn As New MySqlConnection(ConnString)
Dim command As New MySqlCommand
Dim ds As New DataSet
Dim sql As String
Dim dt As New DataTable
Dim markers As String = ""
Dim i As Integer = 0
Dim PCList As String = Replace(Me.PostcodeListTextBox.Text, vbLf, "','")
Dim da As New MySqlDataAdapter
Dim myJS As New StringBuilder
PCList = "'" & PCList & "'"
sql = "SELECT postcode, latitude,longitude FROM geocodes WHERE postcode IN (" & PCList & ")"
da = New MySqlDataAdapter(sql, conn)
da.Fill(ds, "locations")
Dim jsonData = GetJson(ds.Tables(0))
'Dim jsondata = DataSetToJSON(ds)
'Me.JsonTextBox.Text = jsonData
myJS.AppendLine("<script type=""text/javascript"">" & vbCrLf)
myJS.AppendLine("var mapOptions = {center: new google.maps.LatLng(54.236107, -4.548055999999974)," & vbCrLf)
myJS.AppendLine("zoom: 6," & vbCrLf)
myJS.AppendLine("mapTypeId : google.maps.MapTypeId.ROADMAP" + "};" & vbCrLf)
myJS.AppendLine("var myMap = new google.maps.Map(document.getElementById('mapArea'), mapOptions);" & vbCrLf)
myJS.AppendLine("var markers = JSON.parse(""<%=jsonData %>"");" & vbCrLf)
myJS.AppendLine("console.log(""<%=jsonData %>"");" & vbCrLf)
myJS.AppendLine("for (i = 0; i < markers.length; i++) {" & vbCrLf)
myJS.AppendLine("var data = markers[i];" & vbCrLf)
myJS.AppendLine("var myLatLng = new google.maps.LatLng(data.latitude, data.longitude);" & vbCrLf)
myJS.AppendLine("var marker = new google.maps.Marker({" & vbCrLf)
myJS.AppendLine("position: myLatLng," & vbCrLf)
myJS.AppendLine("map: myMap," & vbCrLf)
myJS.AppendLine("title: data.postcode" & vbCrLf)
myJS.AppendLine("});" & vbCrLf)
myJS.AppendLine("}" & vbCrLf)
myJS.AppendLine("</script>")
Dim str As String = myJS.ToString
ScriptManager.RegisterStartupScript(Me, Me.GetType(), "Init", myJS.ToString, True)
End Sub
Public Shared Function GetJson(ByVal dt As DataTable) As String
Dim serializer As New System.Web.Script.Serialization.JavaScriptSerializer()
Dim rows As New System.Collections.Generic.List(Of System.Collections.Generic.Dictionary(Of String, Object))()
Dim row As System.Collections.Generic.Dictionary(Of String, Object) = Nothing
For Each dr As DataRow In dt.Rows
row = New System.Collections.Generic.Dictionary(Of String, Object)()
For Each col As DataColumn In dt.Columns
row.Add(col.ColumnName, dr(col))
Next
rows.Add(row)
Next
Return serializer.Serialize(rows)
End Function
下课
此外,我在将 JSON 传递给 javascript 时遇到了问题。
最佳答案
我知道这可以使用 WebMethods 来完成。我希望这与您要找的东西相距不远。
HTML:
<table border="0px" style="width: 100%; font-family: Arial, Helvetica, sans-serif; font-size: small; color: #000000;">
<tr>
<td class="style15" valign="top">
<table border="0px" style="border: 1px solid #000000; font-family: Arial, Helvetica, sans-serif; font-size: small; color: #000000;"width="100%">
<tr>
<td align="center" class="style14" colspan="2">
<textarea ID="PostcodeListTextBox" cols="40" rows="5"></textarea>
</td>
</tr>
<tr>
<td align="center" class="style14" colspan="2">
<button type="button" ID="ShowLocsButton" onclick="GetPostalJSON()">Show Locations</button>
</td>
</tr>
</table>
</td>
<td align="center" valign="top">
<div id="mapArea" style="border:1px solid black"></div>
</td>
</tr>
</table>
至少对于您所解释的内容,您实际上不需要使用服务器端控件。虽然如果你确实想使用它们,我认为你需要为你的选择器添加前缀。前任。 #MainContent_邮政编码列表文本框。
VB.NET
要使用 WebMethods,您需要将 Imports System.Web.Services
添加到您的导入中。
Imports MySql.Data.MySqlClient
Imports MySql.Data
Imports System.Data
Imports System.Web
Imports System.Web.Services
Imports System.IO
Imports System.Configuration
Imports System.Web.Script.Services
Imports System.Web.Script.Serialization
Partial Class admin_routing
Inherits System.Web.UI.Page
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
End Sub
<WebMethod()>
Public Shared Function GetJson(PCList as String) As String
Dim ConnString As String = ConfigurationManager.ConnectionStrings("ConnString").ConnectionString,
conn As New MySqlConnection(ConnString),
da As New MySqlDataAdapter,
ds As New DataSet,
sql = "SELECT postcode, latitude,longitude FROM geocodes WHERE postcode IN (" & PCList & ")"
da = New MySqlDataAdapter(sql, conn)
da.Fill(ds, "locations")
Dim dt as DataTable = ds.Tables(0)
Dim rows As New System.Collections.Generic.List(Of System.Collections.Generic.Dictionary(Of String, Object))(),
row As System.Collections.Generic.Dictionary(Of String, Object) = Nothing
For Each dr As DataRow In dt.Rows
row = New System.Collections.Generic.Dictionary(Of String, Object)()
For Each col As DataColumn In dt.Columns
row.Add(col.ColumnName, dr(col))
Next
rows.Add(row)
Next
Dim serializer As New System.Web.Script.Serialization.JavaScriptSerializer()
Return serializer.Serialize(rows)
End Function
我删除了所有不必要的代码,并将用于构建 DataTable 的代码移到了 GetJson 函数中,但除此之外它与您拥有的代码相同。如果您发现有任何遗漏(例如您在何处构建您在何处使用的邮政编码字符串),它会在 JS 中完成。见下文。
Javascript:
<script type="text/javascript">
var myMap;
function GetPostalJSON(){
var res = $("#PostcodeListTextBox").val().split("\n"),
postCodeStr = "";
for (var i = 0; i < res.length; i++) {
if (i > 0) {
postCodeStr += ","
}
postCodeStr += "'" + res[i].trimRight() + "'"
}
PageMethods.GetJson(postCodeStr, function(result){
UpdateMarkers(result)
});
}
function CreateMap(){
var mapOptions = {
center: new google.maps.LatLng(54.236107, -4.548055999999974),
zoom: 6,
mapTypeId : google.maps.MapTypeId.ROADMAP
};
myMap = new google.maps.Map(document.getElementById('mapArea'), mapOptions);
}
function UpdateMarkers(jsonData){
if (myMap == null) CreateMap()
var markers = JSON.parse(jsonData);
console.log(jsonData);
for(i =0; i < markers.length; i++) {
var data = marker[i];
var myLatLng = new google.maps.LatLng(data.latitude, data.longitude);
var marker = new google.maps.Marker({
position: myLatLng,
map: myMap,
title: data.postcode
});
}
}
</script>
基本上,您使用 StringBuilder 构建的任何 JS 我都会放在前端。每次有人按下按钮时都创建一个 map 似乎是一种浪费,因此您不妨将其设为全局并在修改之前检查它是否已创建。您可能不认识的是 PageMethods.GetJson 部分。这调用了 WebMethod。
关于javascript - 在下一个循环中更新面板问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40363941/
我需要将文本放在 中在一个 Div 中,在另一个 Div 中,在另一个 Div 中。所以这是它的样子: #document Change PIN
奇怪的事情发生了。 我有一个基本的 html 代码。 html,头部, body 。(因为我收到了一些反对票,这里是完整的代码) 这是我的CSS: html { backgroun
我正在尝试将 Assets 中的一组图像加载到 UICollectionview 中存在的 ImageView 中,但每当我运行应用程序时它都会显示错误。而且也没有显示图像。 我在ViewDidLoa
我需要根据带参数的 perl 脚本的输出更改一些环境变量。在 tcsh 中,我可以使用别名命令来评估 perl 脚本的输出。 tcsh: alias setsdk 'eval `/localhome/
我使用 Windows 身份验证创建了一个新的 Blazor(服务器端)应用程序,并使用 IIS Express 运行它。它将显示一条消息“Hello Domain\User!”来自右上方的以下 Ra
这是我的方法 void login(Event event);我想知道 Kotlin 中应该如何 最佳答案 在 Kotlin 中通配符运算符是 * 。它指示编译器它是未知的,但一旦知道,就不会有其他类
看下面的代码 for story in book if story.title.length < 140 - var story
我正在尝试用 C 语言学习字符串处理。我写了一个程序,它存储了一些音乐轨道,并帮助用户检查他/她想到的歌曲是否存在于存储的轨道中。这是通过要求用户输入一串字符来完成的。然后程序使用 strstr()
我正在学习 sscanf 并遇到如下格式字符串: sscanf("%[^:]:%[^*=]%*[*=]%n",a,b,&c); 我理解 %[^:] 部分意味着扫描直到遇到 ':' 并将其分配给 a。:
def char_check(x,y): if (str(x) in y or x.find(y) > -1) or (str(y) in x or y.find(x) > -1):
我有一种情况,我想将文本文件中的现有行包含到一个新 block 中。 line 1 line 2 line in block line 3 line 4 应该变成 line 1 line 2 line
我有一个新项目,我正在尝试设置 Django 调试工具栏。首先,我尝试了快速设置,它只涉及将 'debug_toolbar' 添加到我的已安装应用程序列表中。有了这个,当我转到我的根 URL 时,调试
在 Matlab 中,如果我有一个函数 f,例如签名是 f(a,b,c),我可以创建一个只有一个变量 b 的函数,它将使用固定的 a=a1 和 c=c1 调用 f: g = @(b) f(a1, b,
我不明白为什么 ForEach 中的元素之间有多余的垂直间距在 VStack 里面在 ScrollView 里面使用 GeometryReader 时渲染自定义水平分隔线。 Scrol
我想知道,是否有关于何时使用 session 和 cookie 的指南或最佳实践? 什么应该和什么不应该存储在其中?谢谢! 最佳答案 这些文档很好地了解了 session cookie 的安全问题以及
我在 scipy/numpy 中有一个 Nx3 矩阵,我想用它制作一个 3 维条形图,其中 X 轴和 Y 轴由矩阵的第一列和第二列的值、高度确定每个条形的 是矩阵中的第三列,条形的数量由 N 确定。
假设我用两种不同的方式初始化信号量 sem_init(&randomsem,0,1) sem_init(&randomsem,0,0) 现在, sem_wait(&randomsem) 在这两种情况下
我怀疑该值如何存储在“WORD”中,因为 PStr 包含实际输出。? 既然Pstr中存储的是小写到大写的字母,那么在printf中如何将其给出为“WORD”。有人可以吗?解释一下? #include
我有一个 3x3 数组: var my_array = [[0,1,2], [3,4,5], [6,7,8]]; 并想获得它的第一个 2
我意识到您可以使用如下方式轻松检查焦点: var hasFocus = true; $(window).blur(function(){ hasFocus = false; }); $(win
我是一名优秀的程序员,十分优秀!