Вызов функции после загрузки результатов пользовательского поиска Google?

Мне нужно выполнить код jQuery после того, как результаты поиска будут отображены на моей странице. Я могу использовать любой код v1:

Loading

 
 google.load('search', '1', {language : 'en', style : google.loader.themes.V2_DEFAULT});
 google.setOnLoadCallback(function() {
var customSearchOptions = {};
var orderByOptions = {};
orderByOptions['keys'] = [{label: 'Relevance', key: ''},{label: 'Date', key: 'date'}];
customSearchOptions['enableOrderBy'] = true;
customSearchOptions['orderByOptions'] = orderByOptions;  var customSearchControl = new google.search.CustomSearchControl(
  'zzzzzzzzzzzz', customSearchOptions);
customSearchControl.setResultSetSize(google.search.Search.FILTERED_CSE_RESULTSET);
var options = new google.search.DrawOptions();
options.setAutoComplete(true);
customSearchControl.setAutoCompletionId('zzzzzz:zzzzzzz+qptype:3');
options.enableSearchResultsOnly(); 
customSearchControl.draw('cse', options);
function parseParamsFromUrl() {
  var params = {};
  var parts = window.location.search.substr(1).split('\x26');
  for (var i = 0; i < parts.length; i++) {
    var keyValuePair = parts[i].split('=');
    var key = decodeURIComponent(keyValuePair[0]);
    params[key] = keyValuePair[1] ?
        decodeURIComponent(keyValuePair[1].replace(/\+/g, ' ')) :
        keyValuePair[1];
  }
  return params;
}

var urlParams = parseParamsFromUrl();
var queryParamName = "q";
if (urlParams[queryParamName]) {
  customSearchControl.execute(urlParams[queryParamName]);
}
  }, true);

Или код v2: я




    (function() {
var cx = 'xxxxxxxxx';
var gcse = document.createElement('script'); gcse.type = 'text/javascript'; gcse.async = true;
gcse.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') +
    '//www.google.com/cse/cse.js?cx=' + cx;
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(gcse, s);
  })();

Я пытался поместить мой вызов функции в разные места кода, но безрезультатно.

У меня есть функция, которая должна динамически устанавливать высоту контейнера, в котором отображаются результаты поиска, поэтому после загрузки результатов мне нужно вызвать ее, иначе моя страница отображается неправильно.

Вот ссылка на их документацию API v2:https://developers.google.com/custom-search/docs/element#cse-element и v1:https://developers.google.com/custom-search/docs/js/cselement-reference , Я могу'не видеть ничего, где есть обратный вызов при рендеринге результата поиска, только при инициализации. Кажется сумасшедшим, хотя нетне поддерживает что-то вроде этого.

Вот что яя пробовал с v2:

(function () {
        var cx = 'xxxxxxxxx';
        var gcse = document.createElement('script'); gcse.type = 'text/javascript'; gcse.async = true;

        gcse.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') +
            '//www.google.com/cse/cse.js?cx=' + cx;
        gcse.onreadystatechange = gcse.onload = function () {
            console.log("executed");
            SetMainHeight(20);
        };
        var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(gcse, s);

    })();

Консоль никогда не выводитказнены», Также я замечаю в своей консоли, у меня есть следующая ошибка:

Небезопасная попытка JavaScript получить доступ к фрейму с помощью URL about: blank из фрейма с URLhttp://www.google.com/cse?q=test&клиент = Google-кооп &гл = еп &г = s &сх = ххххх ...s1% 2Csr1 &rurl = HTTP% 3A% 2F% 2Flocalhost% 3A58257% 2FSearch% 3Fq% 3Dtest # ведомое-1-1. Домены, протоколы и порты должны совпадать.

Не уверен, что это важно, так как функция поиска все еще работает нормально. Я проверяю это на локальном хосте через http.

Ответы на вопрос(3)

Ваш ответ на вопрос