我有一个中继器可以在客户端 JavaScript 中生成一个数组(用于谷歌地图标记)。它在第一次加载时工作正常,但是当我触发回发并将转发器与其他数据绑定(bind)时。中继器会将初始数组值返回给我的变量。有什么方法出错吗?请帮忙
<script type="text/javascript">
Var markers = [];
function LoadMarker() {
markers = [];
var data =[
<asp:Repeater ID="rptMarkers" runat="server">
<ItemTemplate>
{
"title": '<%# Eval("DeviceName") %>',
"lat": '<%# Eval("Latitude") %>',
"lng": '<%# Eval("Longitude") %>',
"Origlat": '<%# Eval("OrigLatitude") %>',
"Origlng": '<%# Eval("OrigLongitude") %>',
"description": '<%# Eval("Description") %>',
"Status": '<%# Eval("Status") %>',
"Active": '<%# Eval("Active") %>'
}
</ItemTemplate>
<SeparatorTemplate>
,
</SeparatorTemplate>
</asp:Repeater>];
markers = data;
}
最佳答案
中继器对我不起作用,但我找到了替代方案。从代码后面使用 JavaScriptSerializer 序列化数据集。然后将其解析为隐藏字段以便客户端代码可以访问。
HTML
<asp:HiddenField ID="hfSortOrder" runat="server" />
JS
var markers = [];
markers = JSON.parse(document.get`enter code here`ElementById('<%= hfDummy.ClientID%>').value);
for (i = 0; i < markers.length; i++) {
var data = markers[i]
//Do your stuff etc: var info = data.column1
}
VB.NET
Dim dsdata As New DataSet
Dim dt As New DataTable()
Dim serializer As New System.Web.Script.Serialization.JavaScriptSerializer()
Dim rows As New List(Of Dictionary(Of String, Object))()
Dim row As Dictionary(Of String, Object)
dsdata = ReadData()
For Each dr As DataRow In dt.Rows
row = New Dictionary(Of String, Object)()
For Each col As DataColumn In dt.Columns
row.Add(col.ColumnName, dr(col))
Next
rows.Add(row)
Next
hfDummy.Value = serializer.Serialize(rows)
关于ASP Repeater 生成的 Javascript 数组未更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28339726/