методам константы также позволяют изменить статических местных жителей. Например, следующее совершенно законно (и повторенные вызовы к панели () возвратят увеличивающие стоимости - не кэшируемый 0):
class Foo
{
public:
int bar() const
{
static int x = 0;
return x++;
}
};
Я предполагаю, что вы хотите использовать синхронное событие, чтобы ваша функция String.prototype.getLanguage () просто возвращала JSON. К сожалению, вы не можете сделать это с помощью jQuery из удаленного API.
Насколько я знаю, jQuery не поддерживает синхронных объектов XMLHttpRequest , и даже если бы это было так, вам бы потребовался прокси на вашем сервере, чтобы сделать запрос синхронизации, избегая ограничений политики одинакового происхождения .
Однако вы можете делать все, что хотите, используя поддержку jQuery для JSONP. Если мы просто напишем String.prototype.getLanguage () для поддержки обратного вызова:
String.prototype.getLanguage = function( callback ) {
var thisObj = this;
var url = 'http://ajax.googleapis.com/ajax/services/language/detect?v=1.0&q=' + this + '&callback=?';
$.getJSON( url,function(json) {
callback.call(thisObj,json.responseData.language);
});
}
Тогда мы сможем использовать функцию как таковую:
'this is my string'.getLanguage( function( language ) {
//Do what you want with the result here, but keep in mind that it is async!
alert(this);
alert(language);
});
var test = function(fun)
{
String.prototype.getLanguage = function() {
.getJSON('http://ajax.googleapis.com/ajax/services/language/detect?v=1.0&q=' + this + '&callback=?',
function(json) {
fun.call(json.responseData.language);
});
};
};
test(retCall);
var retCall = function(xjson){
alert(xjson);
};