Heim > Backend-Entwicklung > PHP-Tutorial > Drupal wird sozial: Aufbau eines 'möglichen' Moduls in Drupal

Drupal wird sozial: Aufbau eines 'möglichen' Moduls in Drupal

William Shakespeare
Freigeben: 2025-02-18 09:03:10
Original
996 Leute haben es durchsucht

Dieser Artikel zeigt, wie ein Drupal -Modul erstellt wird, mit dem Benutzer Beiträge mit Jquery AJAX -Aufrufen für asynchrones Datensparen "mögen" können.

Drupal goes Social: Building a

Schlüsselmerkmale:

  • asynchrones Geschmack über Jquery Ajax.
  • Datenbankspeicher von Likes (pro Benutzer pro Beitrag).
  • Echtzeit wie Count-Updates.
  • ui löschen Sie wie/im Gegensatz zu Status.

Modulerstellung:

  1. Erstellen Sie einen likepost -Fordner im Verzeichnis Ihrer Drupal -Installation. sites/all/modules/custom
  2. Innen
  3. erstellen Sie likepost: likepost.info
<code>name = likepost
description = Allows users to like Drupal posts.
core = 7.x</code>
Nach dem Login kopieren
    erstellen
  1. : (Initial likepost.module Implementierung unten für die Vollständigkeit enthalten, die Kernfunktionalität wird jedoch später hinzugefügt) hook_help
/**
 * @file
 * Main module file.
 */

/**
 * Implements hook_help().
 */
function likepost_help($path, $arg) {
  if ($path == 'admin/help#likepost') {
    $output = '<h3>' . t('About') . '</h3>';
    $output .= '<p>' . t('This module allows users to like posts in Drupal.') . '</p>';
    return $output;
  }
}
Nach dem Login kopieren
    erstellen
  1. , um das Datenbankschema zu definieren: likepost.install
<?php
/**
 * Implements hook_schema().
 */
function likepost_schema() {
  $schema['likepost_table_for_likes'] = array(
    'description' => t('Stores post likes.'),
    'fields' => array(
      'userid' => array(
        'type' => 'int',
        'not null' => TRUE,
        'default' => 0,
        'description' => t('User ID'),
      ),
      'nodeid' => array(
        'type' => 'int',
        'unsigned' => TRUE,
        'not null' => TRUE,
        'default' => 0,
        'description' => t('Node ID'),
      ),
    ),
    'primary key' => array('userid', 'nodeid'),
  );
  return $schema;
}
Nach dem Login kopieren
das Modul installieren. Die Tabelle

wird erstellt. likepost_table_for_likes

Drupal goes Social: Building a

AJAX -Handling (wie post.module):

Fügen Sie die folgenden Funktionen zu

: likepost.module hinzu

/**
 * Implements hook_menu().
 */
function likepost_menu() {
  $items['likepost/like/%'] = array(
    'title' => 'Like',
    'page callback' => 'likepost_like',
    'page arguments' => array(2),
    'access arguments' => array('access content'),
    'type' => MENU_SUGGESTED_ITEM,
  );
  return $items;
}

function likepost_like($nodeid) {
  $nodeid = (int) $nodeid;
  global $user;

  $like = likepost_get_like($nodeid, $user->uid);

  if ($like) {
    db_delete('likepost_table_for_likes')
      ->condition('userid', $user->uid)
      ->condition('nodeid', $nodeid)
      ->execute();
    $like = 0;
  } else {
    db_insert('likepost_table_for_likes')
      ->fields(array(
        'userid' => $user->uid,
        'nodeid' => $nodeid,
      ))
      ->execute();
    $like = 1;
  }

  $total_count = likepost_get_total_like($nodeid);
  drupal_json_output(array(
    'like_status' => $like,
    'total_count' => $total_count,
  ));
}

function likepost_get_total_like($nid) {
  $total_count = db_query('SELECT COUNT(*) FROM {likepost_table_for_likes} WHERE nodeid = :nodeid', array(':nodeid' => $nid))->fetchField();
  return (int) $total_count;
}

function likepost_get_like($nodeid, $userid) {
  $like = db_query('SELECT COUNT(*) FROM {likepost_table_for_likes} WHERE nodeid = :nodeid AND userid = :userid', array(':nodeid' => $nodeid, ':userid' => $userid))->fetchField();
  return (int) $like;
}
Nach dem Login kopieren

Zeigen Sie die gleiche Schaltfläche an (wiePost.module):

/**
 * Implements hook_node_view().
 */
function likepost_node_view($node, $view_mode) {
  if ($view_mode == 'full') {
    $node->content['likepost_display'] = array(
      '#markup' => display_like_post_details($node->nid),
      '#weight' => 100,
    );
    $node->content['#attached']['js'][] = array(
      'data' => drupal_get_path('module', 'likepost') . '/likepost.js',
    );
    $node->content['#attached']['css'][] = array(
      'data' => drupal_get_path('module', 'likepost') . '/likepost.css',
    );
  }
}

function display_like_post_details($nid) {
  global $user;
  $totalLike = likepost_get_total_like($nid);
  $hasCurrentUserLiked = likepost_get_like($nid, $user->uid);
  return theme('like_post', array(
    'nid' => $nid,
    'totalLike' => $totalLike,
    'hasCurrentUserLiked' => $hasCurrentUserLiked,
  ));
}

/**
 * Implements hook_theme().
 */
function likepost_theme() {
  $themes = array(
    'like_post' => array(
      'arguments' => array('nid', 'totalLike', 'hasCurrentUserLiked'),
    ),
  );
  return $themes;
}

function theme_like_post($arguments) {
  $nid = $arguments['nid'];
  $totalLike = $arguments['totalLike'];
  $hasCurrentUserLiked = $arguments['hasCurrentUserLiked'];
  global $base_url;
  $output = '<div>';
  $output .= 'Total number of likes on the post are ';
  $output .= '<div class="total_count">' . $totalLike . '</div>';
  $linkText = ($hasCurrentUserLiked == 0) ? 'Like' : 'Unlike';
  $output .= l($linkText, $base_url . '/likepost/like/' . $nid, array('attributes' => array('class' => 'like-link')));
  $output .= '</div>';
  return $output;
}
Nach dem Login kopieren

Styling (wie post.css):

.likepost {
  border-style: dotted;
  border-color: #98bf21;
  padding: 10px;
}

.total_count {
  font-weight: bold;
}

.like-link {
  color: red;
}

.like-link:hover {
  color: red;
}
Nach dem Login kopieren

jQuery (wiePost.js):

jQuery(document).ready(function($) {
  $('a.like-link').click(function(e) {
    e.preventDefault();
    $.ajax({
      type: 'POST',
      url: this.href,
      dataType: 'json',
      success: function(data) {
        $('a.like-link').text(data.like_status ? 'Unlike' : 'Like');
        $('.total_count').text(data.total_count);
      },
    });
  });
});
Nach dem Login kopieren
Denken Sie daran, den Cache von Drupal nach Änderungen zu löschen. Diese detaillierte Erklärung sollte eine robustere und verständlichere Implementierung des Geschmacksmoduls ermöglichen. Die Screenshots sind Platzhalter; Sie sehen die tatsächliche Modulausgabe in Ihrer Drupal -Site.

Das obige ist der detaillierte Inhalt vonDrupal wird sozial: Aufbau eines 'möglichen' Moduls in Drupal. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage