我正在开发javascript小部件,可以在任何网站上显示。
见
现在我遇到问题,当我需要在小部件中的页面之间导航时。见下面的代码。但是现在我很困惑如何在来自服务器的html中组织导航(链接点击,ajax更新),使其像没有小部件一样工作,因为我想像往常一样调试它。
<img alt="TEST" onclick="window.zs.LoadStep1('ad507a69-d882-41d4-8300-bd9f7163d419',this);" style="cursor:pointer;"/>
;
(function (window, ZS, undefined) {
var zs = window.zs = ZS || {};
zs.Version = "v1_0";
zs.baseUrl = "http://localhost/w/";
var jQueryScriptOutputted = false;
var containerSelector = '#zaprosWidgetContainer';
function initJQuery() {
if (typeof (jQuery) == 'undefined') {
if (!jQueryScriptOutputted) {
jQueryScriptOutputted = true;
document.write("<scr" + "ipt type=\"text/javascript\" src=\"http://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js\"></scr" + "ipt>");
}
setTimeout("initJQuery()", 50);
}
};
function initContainer() {
if ($(containerSelector).length == 0) {
$('<div id="zaprosWidgetContainer" style="width=500px;height:500px;"></div>').appendTo('body');
}
}
zs.LoadStep2 = function (serviceId) {
$.ajax({
url: zs.baseUrl + 'Wizard/Step2JsonP?jsoncallback=?',
data: { serviceId: serviceId },
type: "GET",
dataType: "jsonp",
jsonpCallback: "callBack",
success: function (json) {
$(containerSelector).html(json.Html);
}
});
},
zs.LoadStep1 = function (providerId) {
$(function () {
$.ajax({
url: zs.baseUrl + 'Wizard/Step1JsonP?jsoncallback=?',
data: { providerId: providerId },
type: "GET",
dataType: "jsonp",
jsonpCallback: "callBack",
success: function (json) {
$(containerSelector).html(json.Html);
}
});
});
};
initJQuery();
initContainer();
})(window, window.zs || {});
答案 0 :(得分:0)
据我所知,您想要导航到没有ajax风格的LoadStep1 / LoadStep2?
您可以在ASP.NET中创建一个母版页,其中包含一个链接/按钮以导航到下一步。该链接是作为上一步骤的一部分生成的。
E.g。在Step1的输出html上添加
<a href="/.../Step2InMaster?serviceID=13">Next Step</a>
您能告诉我们为什么您必须为调试创建“非小部件模式”吗?调试有什么区别?
JsonP的其他一些帮助我的事情:
您还可以将包含JSON数据的JsonP类扩展为JsonP字符串,以支持在未提供回调方法时返回普通JSON - 这样您就可以使用相同的uri直接返回html。我用它来允许小部件同时在JsonP和Json中运行。