Rumah  >  Artikel  >  rangka kerja php  >  Bagaimana untuk membangunkan sistem pengundian dalam talian menggunakan Laravel

Bagaimana untuk membangunkan sistem pengundian dalam talian menggunakan Laravel

WBOY
WBOYasal
2023-11-02 18:31:561216semak imbas

Bagaimana untuk membangunkan sistem pengundian dalam talian menggunakan Laravel

Cara menggunakan Laravel untuk membangunkan sistem pengundian dalam talian

Pengenalan:
Dengan perkembangan Internet, lebih banyak perkara boleh dilakukan dalam talian, termasuk mengundi. Sistem pengundian dalam talian boleh mengumpul pendapat dan maklum balas daripada sebilangan besar pengguna dengan mudah dan cekap. Artikel ini akan memperkenalkan cara menggunakan rangka kerja Laravel untuk membangunkan sistem pengundian dalam talian asas dan menyediakan contoh kod khusus.

1. Persediaan persekitaran dan pemasangan Laravel:

  1. Pastikan PHP dan Komposer telah dipasang pada mesin anda. Jika tidak, sila pasang dahulu.
  2. Buka tetingkap baris arahan dan gunakan Komposer untuk memasang Laravel:
    komposer global memerlukan laravel/pemasangcomposer global require laravel/installer
  3. 安装完成后,在命令行中输入以下命令以创建一个新的Laravel项目:
    laravel new votingsystem
  4. 进入项目目录:
    cd votingsystem
  5. 启动Laravel开发服务器:
    php artisan serve
  6. 打开浏览器,访问http://localhost:8000,如果看到Laravel的欢迎页面,说明环境搭建成功。

二、数据库准备:

  1. 在项目根目录中,打开.env文件,配置数据库连接信息。修改以下行:

    DB_CONNECTION=mysql
    DB_HOST=127.0.0.1
    DB_PORT=3306
    DB_DATABASE=voting_system
    DB_USERNAME=root
    DB_PASSWORD=
  2. 创建一个名为voting_system的数据库。

三、创建投票相关的模型、迁移和控制器:

  1. 在命令行中输入以下命令以创建一个Poll模型和相应的数据迁移文件:
    php artisan make:model Poll -m
  2. 在生成的迁移文件中,定义polls表的字段:

    public function up()
    {
        Schema::create('polls', function (Blueprint $table) {
            $table->id();
            $table->string('title');
            $table->timestamps();
        });
    }
  3. 运行数据库迁移:
    php artisan migrate
  4. 创建一个PollController控制器,并添加createstore方法:

    php artisan make:controller PollController --resource
  5. PollController中,添加createstore方法的实现,以便于创建和保存投票:

    <?php
    
    namespace AppHttpControllers;
    
    use IlluminateHttpRequest;
    use AppPoll;
    
    class PollController extends Controller
    {
        public function create()
        {
            return view('polls.create');
        }
    
        public function store(Request $request)
        {
            $this->validate($request, [
                'title' => 'required'
            ]);
    
            $poll = Poll::create([
                'title' => $request->title
            ]);
    
            // 添加投票选项
            foreach($request->options as $option) {
                $poll->options()->create([
                    'name' => $option
                ]);
            }
    
            return redirect()->route('poll.show', $poll->id);
        }
    }
  6. 创建Option模型和相应的数据迁移文件:
    php artisan make:model Option -m
  7. 在生成的Option迁移文件中,定义options表的字段:

    public function up()
    {
        Schema::create('options', function (Blueprint $table) {
            $table->id();
            $table->unsignedBigInteger('poll_id');
            $table->string('name');
            $table->timestamps();
        });
    }
  8. 运行数据库迁移:
    php artisan migrate
  9. Poll模型中,添加与Option模型的关联关系:

    public function options()
    {
        return $this->hasMany(Option::class);
    }

四、创建视图和路由:

  1. resources/views目录下,创建一个名为polls的文件夹,并在其中创建一个create.blade.php视图文件:

    <form action="{{ route('poll.store') }}" method="POST">
        @csrf
        <label for="title">标题:</label>
        <input type="text" name="title">
    
        <label for="options">选项:</label>
        <ul id="options">
            <li>
                <input type="text" name="options[]">
            </li>
        </ul>
        <button id="add-option" type="button">添加选项</button>
    
        <button type="submit">提交</button>
    </form>
    
    <script>
    document.getElementById('add-option').addEventListener('click', function() {
        var option = document.createElement('li');
        option.innerHTML = '<input type="text" name="options[]">';
        document.getElementById('options').appendChild(option);
    });
    </script>
  2. routes/web.php文件中,添加以下路由:

    Route::resource('poll', 'PollController');
  3. 在命令行中运行以下命令以刷新路由缓存:
    php artisan route:cache

五、测试:

  1. 打开浏览器,访问http://localhost:8000/poll/create
  2. Selepas pemasangan selesai, masukkan arahan berikut dalam baris arahan untuk mencipta projek Laravel baharu :
  3. sistem pengundian baharu laravel
  4. Masukkan direktori projek:
  5. sistem undian cd

Mulakan pelayan pembangunan Laravel:
layanan artisan php

Buka pelayar dan lawati http://localhost:8000 Jika anda melihat halaman alu-aluan Laravel, ini bermakna persekitaran telah berjaya disediakan.

🎜🎜2. Penyediaan pangkalan data: 🎜🎜🎜🎜Dalam direktori akar projek, buka fail .env dan konfigurasikan maklumat sambungan pangkalan data. Ubah suai baris berikut: 🎜rrreee🎜🎜Buat pangkalan data bernama voting_system. 🎜🎜🎜3 Cipta model, migrasi dan pengawal yang berkaitan dengan pengundian: 🎜🎜🎜Masukkan arahan berikut pada baris arahan untuk mencipta model Poll dan fail migrasi data yang sepadan: 🎜php artisan make:model Poll -m🎜🎜🎜Dalam fail migrasi yang dijana, takrifkan medan jadual polls: 🎜rrreee🎜🎜Jalankan migrasi pangkalan data: 🎜php artisan migrate🎜🎜🎜Buat pengawal <code>PollController dan tambah kaedah create dan store: 🎜rrreee🎜🎜🎜 dalam PollController , tambahkan pelaksanaan kaedah <code>create dan store untuk memudahkan penciptaan dan menyimpan undian: 🎜rrreee🎜🎜Buat model Option dan Fail pemindahan data yang sepadan: 🎜php artisan make:model Option -m🎜🎜🎜Dalam fail migrasi Option yang dihasilkan, tentukan jadual options Medan: 🎜rrreee🎜🎜Jalankan pemindahan pangkalan data: 🎜php artisan migrate🎜🎜🎜Dalam model Poll, tambahkan perkaitan dengan model Option Hubungan: 🎜rrreee🎜🎜🎜4 Cipta paparan dan laluan: 🎜🎜🎜🎜Dalam direktori sumber/pandangan, buat folder bernama polls dan Cipta create.blade.php lihat fail: 🎜rrreee🎜🎜🎜Dalam fail routes/web.php, tambah laluan berikut: 🎜rrreee🎜🎜Dalam baris arahan Jalankan arahan berikut untuk memuat semula cache laluan: 🎜php artisan route:cache🎜🎜🎜5 Ujian: 🎜🎜🎜Buka penyemak imbas dan lawati http://localhost:8000/poll/ createkod>. 🎜🎜Masukkan tajuk pengundian dan pilihan, dan klik butang "Tambah Pilihan" untuk menambah pilihan secara dinamik. 🎜🎜Setelah selesai mengisi, klik butang "Submit", sistem akan menyimpan undian ke pangkalan data dan melompat ke halaman butiran undian. 🎜🎜🎜Kesimpulan: 🎜Artikel ini memperkenalkan cara membangunkan sistem pengundian dalam talian asas menggunakan rangka kerja Laravel. Dengan mengkonfigurasi persekitaran, mencipta model, migrasi dan pengawal serta menulis pandangan dan laluan, kami melaksanakan fungsi asas pengundian. Anda boleh mengembangkan dan menambah baik lagi sistem atas dasar ini, seperti menambah fungsi seperti pengesahan pengguna dan paparan keputusan pengundian. Saya harap artikel ini akan membantu perjalanan pembangunan Laravel anda. 🎜🎜(Nota: Contoh kod di atas adalah untuk rujukan sahaja, sila buat pelarasan yang sesuai mengikut situasi sebenar.)🎜

Atas ialah kandungan terperinci Bagaimana untuk membangunkan sistem pengundian dalam talian menggunakan Laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn