我有一个 VB .net 应用程序,我试图将其与以前的开发者代码集成。 该代码采用邮政编码并返回商店列表,以及它们在谷歌地图 Canvas 上的位置。
除了一个异常(exception),该过程运行良好。
我得到以下错误
JavaScript runtime error: Accessing the 'caller' property of a function or arguments object is not allowed in strict mode.
我已经将罪魁祸首隔离到
__doPostBack('userControlSearchResults_results', LatLng);
内部有以下内容
function Sys$WebForms$PageRequestManager$_doPostBack(eventTarget, eventArgument) {
var event = window.event;
if (!event) {
var caller = arguments.callee ? arguments.callee.caller : null;
if (caller) {
var recursionLimit = 30;
while (caller.arguments.callee.caller && --recursionLimit) {
caller = caller.arguments.callee.caller; // ERRORS HERE
}
event = (recursionLimit && caller.arguments.length) ? caller.arguments[0] : null;
}
}
...
我的第一个想法是创建一个 window.event,这样它就可以通过 if(!event) 并继续前进。 因为,还有其他时候我们在代码中调用 __doPostback 并且它是成功的。
但是,由于我的 JavaScript 有限,我要么做错了,要么需要找到不同的方法。
我已经搜索过这个问题,但很少有结果。常见的 react 是只注释掉“use strict”;继续前进。
问题是我们引入了很多 JavaScript 库,其中许多现在都设置为“使用严格”
有人对如何解决这个问题有建议或想法吗?
博客提到尝试在 __doPostback 调用之前应用 setTimeout()。 但是,我看不出这将如何解决任何问题。
编辑:添加了更多代码。
__doPostback 在下面的 javascript 中
function CompleteSearch(returnedLatLng) {
if (returnedLatLng != '') {
alert("dopostback here2- this is where it breaks");
__doPostBack('ucSearchResults_udpResults', returnedLatLng);
if (document.getElementById("sidebar_search")) { document.getElementById("sidebar_search").style.display = "none" };
if (document.getElementById("sidebar_login")) { document.getElementById("sidebar_login").style.display = "none" };
if (document.getElementById("promo1")) { document.getElementById("promo1").style.display = "none" };
document.getElementById("sidebar_results").style.display = "block";
//document.getElementById("sidebar_results").style.display = "none";
}
return false;
}
我的更新面板在用户控件中,看起来像这样......
<form id="Form1" runat="server">
<asp:ScriptManager ID="ScriptManager1" runat="server" />
<div id="Container" style="zoom:1" onclick="">
<asp:UpdatePanel runat="server" ID="udpResults" OnLoad="UpdatePanel1_Load">
<ContentTemplate>
<asp:HiddenField ID="currentLatLong" runat="server" />
<asp:HiddenField ID="triggerSearch" runat="server" Value="0" />
<asp:HiddenField ID="searchString" runat="server" Value="0" />
<asp:HiddenField ID="locationCode" runat="server" />
<asp:HiddenField ID="locationDesc" runat="server" />
<asp:HiddenField ID="locationPhone" runat="server" />
<asp:HiddenField ID="locationZip" runat="server" />
<asp:HiddenField ID="filterPickup" runat="server" />
<asp:HiddenField ID="filterVirtualKiosk" runat="server" />
<asp:HiddenField ID="filterDelivery" runat="server" />
<asp:HiddenField ID="filterAcceptsCash" runat="server" />
<asp:HiddenField ID="filterKey2Key" runat="server" />
<asp:HiddenField ID="filterHODService" runat="server" />
<asp:Label ID="tblResults" runat="server"></asp:Label>
</ContentTemplate>
</asp:UpdatePanel>
</div>
</form>
这有帮助还是需要更多代码。 我现在真的被困住了,不知道从哪里开始。
最佳答案
当 window.event 包含 null 时会出现此问题。
我发现它仅在 JavaScript 计时器事件中包含 null。
也许它在其他一些特殊事件中也包含 null。
有两种解决方案。
解决方案 A:
1/在定时器事件上:引发用户界面元素事件,如点击
2/在此元素事件的事件处理程序上:调用 __doPostBack
还是有陷阱的
您可能认为您可以创建一个事件对象并在元素上触发它。
这可行,但 window.event 仍将包含 null。
它看起来很奇怪,但我想这是设计使然。
触发元素事件并使 window.event 包含事件而不是 null 的唯一方法是调用此元素单击方法。
方案B:
如果 UpdatePanel 包含 input type="submit"元素,则无需调用 __doPostBack 执行异步回发。
调用这个元素点击方法就够了。
如果 UpdatePanel 不包含输入提交元素,定时器事件处理程序可以创建一个并使用它:
var btn = document.createElement('INPUT');
btn.setAttribute('name', 'timer_dummy_button');
btn.setAttribute('type', 'submit');
btn.setAttribute('value', 'what you like');
btn.setAttribute('style', 'display:none;');
document.getElementById('yourNiceLittleUpdatePanelID').appendChild(btn);
btn.click();
在异步回发中,Page.Request.Form 将包含这些项目:
["yourNiceLittleScriptManagerControlID"] = "yourNiceLittleUpdatePanelID|timer_dummy_button"
["__EVENTTARGET"] = ""
["__EVENTARGUMENT"] = ""
["timer_dummy_button"] = "what you like"
关于javascript - vb .net,涉及严格模式的javascript问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23254763/