Jquery と AJAX を介してページ データを処理しようとしています。文字列を Drupal に送信し、別の文字列を追加して、クライアントに送り返したいと考えています。「Uncaught TypeError: Cannot read property 'messageLog' of null」というエラーが表示されます
これは私がこれまでに持っているものです。助けてくれてありがとう:
Drupal モジュール:
function exoticlang_chat_log_init(){
drupal_add_js('misc/jquery.form.js');
drupal_add_library('system', 'drupal.ajax');
}
function exoticlang_chat_log_permission() {
return array('access ExoticLang Chat Log');
}
/**
* Implementation of hook_menu().
*/
function exoticlang_chat_logger_menu() {
$items = array();
$items['chatlog'] = array(
'title' => t('ChatLog'),
'type' => MENU_CALLBACK,
'page callback' => 'exoticlang chat log ajax',
'access_callback' => 'user_access',
'access arguments' => array('save chat log')
);
return $items;
}
function exoticlang_chat_log_ajax($logData){
$messageLog= 'Drupal has processed this: '.$logData;
ajax_deliver($messageLog);
exit;
}
Javascript:
function sendPrivateMessageLog(privateSessionID, privateChatLog){
var privateMessageLogJson={'user': myNick, 'chatLog': privateChatLog, 'sessionId': privateSessionID}
privateMessageLogJson = JSON.stringify(privateMessageLogJson);
console.log('JSONstringified: ' + privateMessageLogJson);
jQuery.ajax({
type: 'POST',
url: '/chatlog',
success: exoticlangAjaxCompleted,
data:'messageLog=' + privateMessageLogJson,
dataType: 'json'
});
return false;
}
function exoticlangAjaxCompleted(data){
console.log('exoticlangAjaxCompleted!');
console.log('chat log is: ' + data.messageLog);
console.log('chat log is: ' + dump(data.messageLog));
//console.log(dump(data));
}