Konsep Utama
Tutorial ini menunjukkan cara mengintegrasikan jadual pangkalan data DRUPAL 7 adat dengan modul pandangan, membolehkan pertanyaan yang kuat dan keupayaan persembahan data. Kami akan meliputi pandangan yang menyedari struktur jadual modul anda, menentukan pengendali medan untuk paparan, penapisan, dan penyortiran, dan mewujudkan hubungan antara jadual menggunakan gabungan. Proses ini memanfaatkan Pandangan Pengendali - Kelas Menguruskan Paparan, Menyortir, dan Penapisan Operasi - Membolehkan Penyesuaian Di Luar Fungsi Lalai.Panduan ini memberi tumpuan kepada jadual yang tidak diwakili sebagai entiti Drupal. Untuk integrasi entiti dengan pandangan, sila rujuk sumber lain.
Modul sampel, "dedahkan," tersedia (butiran repositori yang ditinggalkan untuk keringkasan). Jadual
(struktur terperinci di bawah) akan digunakan untuk demonstrasi. Data sampel boleh dimasukkan menggunakan arahan MySQL ini: exposed
INSERT INTO `exposed` (`id`, `name`, `deadline`, `node_id`) VALUES (1, 'Danny', 1399477939, 1), (2, 'Peter', 1399477957, 2);
Mengintegrasikan jadual anda dengan pandangan
Integrasi melibatkan dua langkah utama: memaklumkan pandangan mengenai modul anda dan menentukan struktur meja anda.
Langkah 1: memaklumkan pandangan mengenai modul anda
pelaksanaan dalam fail hook_views_api()
modul anda: .module
/** * Implements hook_views_api(). */ function expose_views_api() { return array( 'api' => 3, 'path' => drupal_get_path('module', 'expose') . '/includes/views', ); }Ini menentukan versi API pandangan dan lokasi fail yang berkaitan dengan pandangan anda.
Langkah 2: Menentukan struktur meja anda 3
Kod ini mentakrifkan kumpulan meja dan menetapkannya sebagai jadual asas, menjadikannya tersedia dalam antara muka pandangan. Definisi medan (terperinci seterusnya) akan ditambah di sini. expose.views.inc
hook_views_data()
/** * Implements hook_views_data(). */ function expose_views_data() { $data = array(); $data['exposed']['table']['group'] = t('Exposed'); $data['exposed']['table']['base'] = array( 'title' => t('Exposed'), 'help' => t('Contains records exposed to Views.'), ); // Field definitions (see below) return $data; }
dalam
, tambahkan definisi medan untuk setiap lajur:
Ini menentukan pengendali untuk paparan (), menyusun (hook_views_data()
), dan penapisan (
// ... (previous code) ... // ID field $data['exposed']['id'] = array( 'title' => t('ID'), 'help' => t('Record ID'), 'field' => array('handler' => 'views_handler_field_numeric'), 'sort' => array('handler' => 'views_handler_sort'), 'filter' => array('handler' => 'views_handler_filter_numeric'), ); // Name field $data['exposed']['name'] = array( 'title' => t('Name'), 'help' => t('Record name'), 'field' => array('handler' => 'views_handler_field'), 'sort' => array('handler' => 'views_handler_sort'), 'filter' => array('handler' => 'views_handler_filter_string'), ); // Deadline field $data['exposed']['deadline'] = array( 'title' => t('Deadline'), 'help' => t('Record deadline'), 'field' => array('handler' => 'views_handler_field_date'), 'sort' => array('handler' => 'views_handler_sort_date'), 'filter' => array('handler' => 'views_handler_filter_date'), ); // ... (Node ID field and join definition - see below) ... return $data;
field
Langkah 4: Mengendalikan hubungan (bergabung) sort
filter
menggunakan lajur :
Ini mentakrifkan gabungan dan menentukan pengendali node
untuk paparan, membolehkan akses ke medan berkaitan nod. Hubungan dan hujah juga ditakrifkan untuk penapisan dan penapisan kontekstual berdasarkan id nod. node_id
// ... (previous code) ... // Join definition $data['exposed']['table']['join'] = array( 'node' => array( 'left_field' => 'nid', 'field' => 'node_id', ), ); // Node ID field $data['exposed']['node_id'] = array( 'title' => t('Node ID'), 'help' => t('Node ID'), 'field' => array('handler' => 'views_handler_field_node'), 'sort' => array('handler' => 'views_handler_sort'), 'filter' => array('handler' => 'views_handler_filter_numeric'), 'relationship' => array( 'base' => 'node', 'field' => 'node_id', 'handler' => 'views_handler_relationship', 'label' => t('Node'), ), 'argument' => array( 'handler' => 'views_handler_argument_node_nid', 'numeric' => TRUE, 'validate type' => 'nid', ), ); return $data;
views_handler_field_node
Kesimpulan
Penjelasan terperinci ini menyediakan panduan komprehensif untuk mengintegrasikan jadual tersuai dengan modul pandangan Drupal 7. Ingatlah untuk menyesuaikan pilihan pengendali ke jenis data khusus anda dan memanfaatkan fleksibiliti pengendali tersuai untuk fungsi lanjutan. Seksyen Soalan Lazim dari input asal telah ditinggalkan kerana ia sebahagian besarnya diliputi dalam tindak balas halus ini.
Atas ialah kandungan terperinci Mengekspos Jadual ke Pandangan di Drupal 7. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Laravel memudahkan mengendalikan data sesi sementara menggunakan kaedah flash intuitifnya. Ini sesuai untuk memaparkan mesej ringkas, makluman, atau pemberitahuan dalam permohonan anda. Data hanya berterusan untuk permintaan seterusnya secara lalai: $ permintaan-

Pelanjutan URL Pelanggan PHP (CURL) adalah alat yang berkuasa untuk pemaju, membolehkan interaksi lancar dengan pelayan jauh dan API rehat. Dengan memanfaatkan libcurl, perpustakaan pemindahan fail multi-protokol yang dihormati, php curl memudahkan execu yang cekap

Laravel menyediakan sintaks simulasi respons HTTP ringkas, memudahkan ujian interaksi HTTP. Pendekatan ini dengan ketara mengurangkan redundansi kod semasa membuat simulasi ujian anda lebih intuitif. Pelaksanaan asas menyediakan pelbagai jenis pintasan jenis tindak balas: Gunakan Illuminate \ Support \ Facades \ http; Http :: palsu ([ 'Google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

Adakah anda ingin memberikan penyelesaian segera, segera kepada masalah yang paling mendesak pelanggan anda? Sembang langsung membolehkan anda mempunyai perbualan masa nyata dengan pelanggan dan menyelesaikan masalah mereka dengan serta-merta. Ia membolehkan anda memberikan perkhidmatan yang lebih pantas kepada adat anda

Artikel membincangkan pengikatan statik lewat (LSB) dalam PHP, yang diperkenalkan dalam Php 5.3, yang membolehkan resolusi runtime kaedah statik memerlukan lebih banyak warisan yang fleksibel. Isu: LSB vs polimorfisme tradisional; Aplikasi Praktikal LSB dan Potensi Perfo

Pembalakan PHP adalah penting untuk memantau dan menyahpepijat aplikasi web, serta menangkap peristiwa kritikal, kesilapan, dan tingkah laku runtime. Ia memberikan pandangan yang berharga dalam prestasi sistem, membantu mengenal pasti isu -isu, dan menyokong penyelesaian masalah yang lebih cepat

Laravel memudahkan pengendalian kata kerja HTTP dalam permintaan masuk, menyelaraskan pengurusan operasi yang pelbagai dalam aplikasi anda. Kaedah () dan ismethod () kaedah mengenal pasti dan mengesahkan jenis permintaan. Ciri ini penting untuk membina

Penyimpanan :: Kaedah Muat turun Rangka Kerja Laravel menyediakan API ringkas untuk mengendalikan muat turun fail dengan selamat sambil menguruskan abstraksi penyimpanan fail. Berikut adalah contoh menggunakan penyimpanan :: muat turun () dalam pengawal contoh:


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

Dreamweaver CS6
Alat pembangunan web visual

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan
