Cara membangunkan fungsi carian blog mudah menggunakan MySQL dan Ruby on Rails
Pengenalan:
Dengan populariti blog, pengguna berharap dapat mencari artikel blog yang menarik dengan cepat. Untuk mencapai keperluan ini, adalah sangat penting untuk membangunkan fungsi carian blog yang mudah dan berkesan. MySQL dan Ruby on Rails ialah pangkalan data yang biasa digunakan dan rangka kerja pembangunan web yang menyediakan fungsi berkuasa dan alatan yang mudah digunakan untuk melaksanakan fungsi carian tersebut.
Artikel ini akan memperkenalkan cara membangunkan fungsi carian blog mudah menggunakan MySQL dan Ruby on Rails. Kami akan merangkumi aspek berikut: mengkonfigurasi pangkalan data, mencipta model, menulis pengawal dan pandangan, dan melaksanakan fungsi carian. Pada masa yang sama, artikel ini akan menyediakan contoh kod khusus untuk menunjukkan cara melaksanakan setiap langkah.
Langkah 1: Konfigurasikan pangkalan data
Pertama, kita perlu memasang pangkalan data MySQL dan persekitaran pembangunan Ruby on Rails. Pastikan anda telah memasang kedua-dua alatan dengan betul. Seterusnya, tambahkan maklumat sambungan pangkalan data MySQL pada fail konfigurasi aplikasi Rails anda (config/database.yml). Ini akan membolehkan anda menyambung ke pangkalan data dan berjalan seperti biasa. Berikut ialah konfigurasi contoh:
development: adapter: mysql2 encoding: utf8 database: your_database_name username: your_username password: your_password host: localhost port: 3306
Langkah 2: Cipta model
Dalam contoh ini, kami mengandaikan bahawa catatan blog kami sudah mempunyai model yang dipanggil Article
的模型。使用以下命令创建一个资源生成器:
$ rails generate scaffold Article title:string content:text
此命令将会生成与文章相关的模型、控制器和视图文件。接下来,执行数据库迁移命令以创建相关的表结构:
$ rake db:migrate
步骤三:编写控制器和视图
在我们的例子中,我们将在app/controllers/articles_controller.rb
中编写相关代码。在index
方法中,我们将实现搜索逻辑。以下是一个示例:
def index if params[:search] @articles = Article.where('title LIKE ?', "%#{params[:search]}%") else @articles = Article.all end end
在视图文件app/views/articles/index.html.erb
中,我们将展示搜索表单和搜索结果。以下是示例代码:
<%= form_tag(articles_path, method: :get) do %> <%= text_field_tag(:search, params[:search], placeholder: "Search articles") %> <%= submit_tag("Search", name: nil) %> <% end %> <% @articles.each do |article| %> <h3><%= link_to article.title, article %></h3> <p><%= truncate(article.content, length: 200) %></p> <% end %>
步骤四:实现搜索功能
现在我们已经完成了基本的设置,并在前端展示了搜索表单和搜索结果。接下来,需要修改routes.rb
文件以接受搜索请求。以下是一个示例:
Rails.application.routes.draw do resources :articles do collection do get 'search' end end end
然后,在控制器中创建一个新的方法search
,用于处理搜索逻辑:
def search @articles = Article.search(params[:search]) end
最后,在Article
def self.search(search) if search where('title LIKE ?', "%#{search}%") else all end end
rrreee
Langkah Tiga: Tulis Pengawal dan PaparanDalam kes kami, kami akan berada dalam app/controllers/articles_controller.rb
Tulis kod yang berkaitan . Dalam kaedah index
, kami akan melaksanakan logik carian. Berikut ialah contoh:
rrreee
app/views/articles/index.html.erb
kami akan memaparkan borang carian dan hasil carian. Berikut ialah kod sampel: 🎜rrreee🎜Langkah 4: Laksanakan fungsi carian🎜Kini kami telah melengkapkan tetapan asas dan memaparkan borang carian dan hasil carian di bahagian hadapan. Seterusnya, fail routes.rb
perlu diubah suai untuk menerima permintaan carian. Berikut ialah contoh: 🎜rrreee🎜 Kemudian, buat kaedah baharu Article
Kaedah carian ditambah : 🎜rrreee🎜 Kini anda boleh mencari catatan blog anda dengan menghantar borang carian. 🎜🎜Kesimpulan: 🎜Dalam artikel ini, kami mempelajari cara membangunkan fungsi carian blog mudah menggunakan MySQL dan Ruby on Rails. Kami melaksanakan fungsi ini langkah demi langkah melalui langkah mengkonfigurasi pangkalan data, mencipta model, menulis pengawal dan pandangan serta melaksanakan fungsi carian. Saya harap tutorial ini membantu dan memberi inspirasi kepada anda untuk menggunakan alatan dan teknik ini dengan lebih mendalam dalam projek dunia sebenar. 🎜Atas ialah kandungan terperinci Bagaimana untuk membangunkan fungsi carian blog mudah menggunakan MySQL dan Ruby on Rails. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!