我是CefSharps Chromium浏览器的新手,很难弄清楚如何获取jquery ajax请求的结果。
我的第一次尝试是将我的AJAX请求传递给EvaluateScriptAsync
。实际上脚本有效。它完全符合我的要求,但我没有得到任何结果/状态代码,因为我的Cef-Task不会等到AJAX完成它的工作。
这是一个例子(只是一个示例代码):
var tasks = pdBrowser.EvaluateScriptAsync(@"
(function(){
$.ajax({
type: ""POST"",
dataType: ""json"",
cache: false,
url: ""_resources/php/ajaxRequests.php"",
async: false,
data: {
action: ""insertCrossPlatform"",
type: """",
values: JSON.stringify(""foo bar"")
},
success: function(response) {
if (typeof response === 'string' && response.substring(0, 5) == ""ERROR"")
{
return response;
}
else
{
//pageReload();
return ""OK"";
}
},
error: function(xhr, textStatus, errorThrown) {
return errorThrown + ""\n"" + xhr.responseText;
},
complete: function() {
return ""COMPLETE"";
}
});
})();", null);
tasks.ContinueWith(t =>
{
if (!t.IsFaulted)
{
var response = t.Result;
if (response.Success)
{
if (response.Result != null)
{
MessageBox.Show(response.Result.ToString());
}
}
else
{
MessageBox.Show(response.Message, "Ein Fehler ist aufgetreten", MessageBoxButtons.OK, MessageBoxIcon.Exclamation);
}
}
}, TaskScheduler.Default);
之后我读到有一个SchemeHandler,但我没有正确理解如何实现它。任何人都可以帮助我吗?
提前致谢。
答案 0 :(得分:1)
首先SchemeHandler
不太适合这种情况,通常在提供回复时实施SchemeHandler
。
大多数人选择绑定一个对象,并在他们希望与父应用程序通信时调用绑定对象上的方法。有关示例,请参阅FAQ
。 https://github.com/cefsharp/CefSharp/wiki/Frequently-asked-questions#3-how-do-you-expose-a-net-class-to-javascript
使用49.0.0
,您可以实现ResponseFilter
以获取对底层响应缓冲区的访问权限,它很复杂且没有详细记录,因此如果您不方便通过引用C++
代码进行挖掘,那么此选项不适合你。这是参考https://github.com/cefsharp/CefSharp/blob/cefsharp/49/CefSharp.Example/Filters/PassThruResponseFilter.cs#L17
答案 1 :(得分:-1)
我所做的是通过javascript在页面上创建一个元素,其ID是ajax调用的响应。因此,例如,当您进行ajax调用时,为ajax调用分配ID。
当ajax调用返回时,在页面上写一个元素,其中包含预先指定的id和回调信息。然后你可以使用cefsharp从页面中读取元素内容,这将是你的回调信息。
var myDivElement =document.getElementById('textareaInfo');
if( myDivElement === null)
{
var input = document.createElement('textarea');
input.id = "textareaInfo";
input.value = "Test"
input.rows="4";
input.cols="50";
input.style="height:100%;width:900px;"
var dom = document.getElementsByClassName("page-body")[0];
dom.insertAdjacentElement('afterbegin', input)
}
然后用ajax
var root = 'https://jsonplaceholder.typicode.com';
var _holder = callbackObj;
callbackObj.showMessage(""ajax"");
$.ajax({
url: root + '/posts/1',
contentType: 'application/json; charset=utf-8',
method: 'GET',
complete: function(data){
},
success: function(response) {
$(#'textareaInfo').value(response);
}
}).then(function(data) {
callbackObj.showMessage(data);
});
然后在c#
中阅读来自cefsharp的texarea
chromeBrowser.GetMainFrame()。EvaluateScriptAsync(函数()... $(textareaInfo)。价值)。结果