1 00:00:00,000 --> 00:00:02,538 >> [MUSIC PLAYING] 2 00:00:02,538 --> 00:00:10,800 3 00:00:10,800 --> 00:00:12,390 >> ERIC Ouyang: Hey, semua orang. 4 00:00:12,390 --> 00:00:13,580 Selamat Datang. 5 00:00:13,580 --> 00:00:16,860 Ini adalah Gedung Dinamis Web Apps dengan Laravel. 6 00:00:16,860 --> 00:00:18,290 Nama saya Eric Ouyang. 7 00:00:18,290 --> 00:00:23,860 Saya seorang mahasiswa belajar IPS dengan sekunder dalam ilmu komputer, 8 00:00:23,860 --> 00:00:27,290 dan saya tinggal di Adams Rumah di sini di Harvard. 9 00:00:27,290 --> 00:00:33,340 >> Jadi Laravel, paling inti, adalah kerangka aplikasi web MVC. 10 00:00:33,340 --> 00:00:38,265 Jadi seperti apa yang kalian telah melakukan dengan CS50 Keuangan, 11 00:00:38,265 --> 00:00:42,480 Laravel adalah kerangka kerja yang memungkinkan Anda untuk membangun aplikasi web dinamis. 12 00:00:42,480 --> 00:00:47,710 Jadi Anda bisa memikirkan itu dalam beberapa hal sebagai perpanjangan dari jenis barang 13 00:00:47,710 --> 00:00:50,470 Anda sudah melakukan di CS50 Keuangan, tetapi sistem yang 14 00:00:50,470 --> 00:00:55,890 jauh lebih kuat, banyak lebih elegan dalam beberapa hal, 15 00:00:55,890 --> 00:00:57,870 dan memberikan banyak fungsionalitas untuk Anda 16 00:00:57,870 --> 00:01:03,060 untuk membangun cukup kompleks aplikasi web. 17 00:01:03,060 --> 00:01:05,010 Jadi mari kita pergi melalui beberapa fitur kunci, 18 00:01:05,010 --> 00:01:09,550 dan kemudian kita akan menyelam ke dalam contoh membangun blog 19 00:01:09,550 --> 00:01:12,500 aplikasi dengan Laravel. 20 00:01:12,500 --> 00:01:16,700 >> Jadi salah satu hal pertama yang membedakan dari jenis MVC pekerjaan 21 00:01:16,700 --> 00:01:22,100 bahwa Anda telah melakukan dengan CS50 itu mencakup mesin ORM. 22 00:01:22,100 --> 00:01:27,410 Jadi ORM singkatan objek pemetaan relasional. 23 00:01:27,410 --> 00:01:31,080 Jadi ini memungkinkan Anda untuk membangun lapisan abstraksi 24 00:01:31,080 --> 00:01:35,230 antara database dan pengendali Anda. 25 00:01:35,230 --> 00:01:39,150 Jadi tidak seperti di CS50 Finance mana Anda langsung membuat query, 26 00:01:39,150 --> 00:01:44,790 lapisan ORM memungkinkan Anda untuk abstrak yang jauh dan menciptakan 27 00:01:44,790 --> 00:01:48,085 model yang lebih kuat daripada Anda bisa langsung dengan query SQL. 28 00:01:48,085 --> 00:01:50,590 29 00:01:50,590 --> 00:01:53,510 >> Hal lain yang benar-benar membantu adalah template diwariskan. 30 00:01:53,510 --> 00:01:58,990 Jadi, Anda akan melihat di CS50 Keuangan, Anda akhirnya menulis ulang banyak hal, 31 00:01:58,990 --> 00:02:03,150 di mana tempat Anda bisa berpotensi menggunakan kembali hal-hal, Anda tidak bisa. 32 00:02:03,150 --> 00:02:08,539 Jadi di sini di Laravel, Anda dapat menggunakan apa dikenal sebagai mesin template pisau 33 00:02:08,539 --> 00:02:10,530 untuk membuat tata letak utama. 34 00:02:10,530 --> 00:02:15,840 Dan dari sana, Anda dapat mewarisi sehingga sub-template benar-benar dapat 35 00:02:15,840 --> 00:02:21,210 termasuk unsur-unsur dalam template dasar yang lebih besar. 36 00:02:21,210 --> 00:02:21,810 >> Migrasi. 37 00:02:21,810 --> 00:02:29,010 Jadi ini adalah fitur yang cukup standar pada yang paling modern kerangka kerja aplikasi web. 38 00:02:29,010 --> 00:02:32,710 Jadi ini memungkinkan Anda untuk mewakili perubahan skema database dalam kode. 39 00:02:32,710 --> 00:02:39,200 Jadi tanpa akan mengatakan, phpMyAdmin, Anda benar-benar dapat membuat migrasi ini 40 00:02:39,200 --> 00:02:44,660 di mana Anda mewakili database skema perubahan dalam kode secara langsung. 41 00:02:44,660 --> 00:02:48,070 Dan ini memungkinkan Anda to-- terutama jika Anda memiliki beberapa orang yang bekerja 42 00:02:48,070 --> 00:02:52,650 di web application-- yang sama melacak perubahan ini, 43 00:02:52,650 --> 00:02:55,380 mengatakan di GitHub, atau repositori lainnya. 44 00:02:55,380 --> 00:03:00,880 >> Jadi ini benar-benar membantu dan meringankan kebutuhan 45 00:03:00,880 --> 00:03:04,580 untuk, katakanlah, lulus sekitar banyak SQL kesedihan. 46 00:03:04,580 --> 00:03:07,140 Dan akhirnya, Komposer adalah sesuatu yang benar-benar berguna 47 00:03:07,140 --> 00:03:09,840 yang memungkinkan Anda untuk menggunakan lain kode orang untuk melakukan hal-hal yang mengagumkan. 48 00:03:09,840 --> 00:03:14,020 Jadi Laravel yang disusun sebagai beberapa paket komposer. 49 00:03:14,020 --> 00:03:17,870 Jadi mengatakan jika Anda ingin membawa dalam paket otentikasi 50 00:03:17,870 --> 00:03:23,440 atau jika Anda ingin membawa beberapa semacam script generator atau admin 51 00:03:23,440 --> 00:03:26,910 antarmuka, Anda bisa plug and play komponen-komponen dengan Komposer. 52 00:03:26,910 --> 00:03:30,470 53 00:03:30,470 --> 00:03:31,570 >> Jadi mari kita mulai. 54 00:03:31,570 --> 00:03:35,185 Setiap pertanyaan dari Anda orang sebelum kita mulai? 55 00:03:35,185 --> 00:03:36,500 Tidak ada pertanyaan? 56 00:03:36,500 --> 00:03:37,490 Keren. 57 00:03:37,490 --> 00:03:39,990 Jadi langkah pertama adalah menginstal Komposer. 58 00:03:39,990 --> 00:03:43,590 Jadi Komposer memungkinkan Anda untuk mengelola dependensi ini, 59 00:03:43,590 --> 00:03:47,770 apakah itu kerangka Laravel atau beberapa ekstensi pihak ketiga lainnya. 60 00:03:47,770 --> 00:03:50,400 Perintah pertama memungkinkan Anda untuk men-download Komposer, 61 00:03:50,400 --> 00:03:55,890 dan perintah kedua memungkinkan Anda untuk memindahkannya ke folder bin lokal Anda 62 00:03:55,890 --> 00:04:01,340 sehingga Anda dapat menjalankan Komposer langsung melalui terminal. 63 00:04:01,340 --> 00:04:05,405 >> Setelah itu, pergi ke depan dan membuat proyek Laravel baru. 64 00:04:05,405 --> 00:04:07,280 Kami benar-benar akan menggunakan beberapa contoh kode 65 00:04:07,280 --> 00:04:10,760 bahwa saya telah mengumpulkan untuk membuat blog ini. 66 00:04:10,760 --> 00:04:14,420 Tapi jika Anda mulai dari awal, Anda akan menggunakan perintah ini 67 00:04:14,420 --> 00:04:18,160 di sini, komposer menciptakan proyek, laravel slash laravel, dan kemudian 68 00:04:18,160 --> 00:04:19,940 nama proyek Anda. 69 00:04:19,940 --> 00:04:22,275 Dan itu akan mencakup semua kode distribusi 70 00:04:22,275 --> 00:04:23,733 untuk memulai sebuah proyek Laravel baru. 71 00:04:23,733 --> 00:04:28,870 Jadi untuk CS50 proyek akhir Anda, Anda akan mungkin ingin menggunakan perintah itu. 72 00:04:28,870 --> 00:04:31,210 >> Tapi kita akan mulai dengan ini. 73 00:04:31,210 --> 00:04:34,630 Jadi setelah Anda melakukan itu, Anda akan mendapatkan 74 00:04:34,630 --> 00:04:40,190 jumlah yang cukup luas file dalam blog50. 75 00:04:40,190 --> 00:04:43,840 Jadi mari kita pergi melalui beberapa komponen tersebut. 76 00:04:43,840 --> 00:04:49,060 Anda akan melihat di rute ini direktori, ada folder aplikasi. 77 00:04:49,060 --> 00:04:52,960 Di dalam folder aplikasi, ada beberapa folder membantu. 78 00:04:52,960 --> 00:04:56,330 Dari catatan untuk memulai dengan adalah folder config ini. 79 00:04:56,330 --> 00:04:59,210 Jadi ini set up bagaimana aplikasi web Anda 80 00:04:59,210 --> 00:05:04,350 akan, katakanlah, mengotentikasi orang atau hal tunai atau koneksi ke database. 81 00:05:04,350 --> 00:05:06,400 >> Dan apa yang benar-benar membantu adalah bahwa Laravel 82 00:05:06,400 --> 00:05:09,130 memungkinkan Anda untuk mengatur berbeda lingkungan pengembangan. 83 00:05:09,130 --> 00:05:12,090 Jadi apa yang kita lakukan di sini adalah jika kita pergi di bawah folder lokal, 84 00:05:12,090 --> 00:05:14,720 ada file database.php. 85 00:05:14,720 --> 00:05:18,320 Dan Anda akan melihat di sini bahwa kita mengatur koneksi MySQL yang 86 00:05:18,320 --> 00:05:22,230 memungkinkan individu untuk menghubungkan ke server MySQL yang 87 00:05:22,230 --> 00:05:24,310 langsung pada alat CS50. 88 00:05:24,310 --> 00:05:26,980 Dan kami menghubungkan ke database yang saya set disebut Blog50. 89 00:05:26,980 --> 00:05:31,390 90 00:05:31,390 --> 00:05:37,085 >> Jadi mari kita benar-benar pergi ke depan dan menjalankan versi kerja ini, 91 00:05:37,085 --> 00:05:39,710 hanya untuk mendapatkan rasa apa aplikasi yang kita sedang membangun 92 00:05:39,710 --> 00:05:41,390 seperti. 93 00:05:41,390 --> 00:05:46,150 Jadi saya memiliki salinan Blog50 ini selesai. 94 00:05:46,150 --> 00:05:51,910 Jadi Laravel sebenarnya telah dibangun di server 95 00:05:51,910 --> 00:05:53,910 Anda dapat menjalankan langsung dari baris perintah. 96 00:05:53,910 --> 00:05:56,900 Jadi ini mirip dengan PSet sebelumnya ketika Anda benar-benar 97 00:05:56,900 --> 00:06:00,580 membangun server sendiri di C. Jadi mereka memiliki satu built in sehingga 98 00:06:00,580 --> 00:06:04,010 Anda dapat menjalankan aplikasi Laravel Anda langsung dari baris perintah. 99 00:06:04,010 --> 00:06:11,650 >> Jadi jika kita melakukan php tukang melayani, ini akan meluncurkan server pembangunan 100 00:06:11,650 --> 00:06:13,880 pada port 8.000. 101 00:06:13,880 --> 00:06:18,250 Jadi, jika kita pergi ke host lokal 8.000, Anda akan melihat bahwa, hei. 102 00:06:18,250 --> 00:06:20,800 Kami memiliki blog kita dan berjalan. 103 00:06:20,800 --> 00:06:25,090 Jadi Laravel sini adalah menghasilkan halaman depan blog kita. 104 00:06:25,090 --> 00:06:26,350 Aplikasi yang sangat sederhana. 105 00:06:26,350 --> 00:06:28,610 Tapi ada beberapa fitur yang sangat bagus 106 00:06:28,610 --> 00:06:31,346 bahwa ia menyediakan bawah tenda. 107 00:06:31,346 --> 00:06:33,680 >> Jadi aplikasi blog mudah. 108 00:06:33,680 --> 00:06:36,430 Jika kita ingin membuat sebuah tulisan, kita dapat mengklik tombol itu. 109 00:06:36,430 --> 00:06:40,470 Kita dapat mengatakan, "Hei, semua orang. 110 00:06:40,470 --> 00:06:44,530 Ini adalah benar-benar menyenangkan seminar, "misalnya. 111 00:06:44,530 --> 00:06:46,560 Dan menulis sesuatu di sini. 112 00:06:46,560 --> 00:06:48,180 Teks di sini. 113 00:06:48,180 --> 00:06:51,327 Jika kita klik Submit, Anda akan melihat bahwa blog baru 114 00:06:51,327 --> 00:06:53,410 posting telah ditambahkan ke Halaman depan blog. 115 00:06:53,410 --> 00:06:56,532 116 00:06:56,532 --> 00:06:59,970 Jika kita kembali ke sini, Anda akan melihat bahwa ada beberapa komentar yang sudah 117 00:06:59,970 --> 00:07:01,160 di blog. 118 00:07:01,160 --> 00:07:03,630 Jadi jika kita scroll ke bawah, Anda akan melihat bahwa Jonathan Tan mengatakan 119 00:07:03,630 --> 00:07:08,020 bahwa ia sangat tertarik dengan posting ini. 120 00:07:08,020 --> 00:07:11,570 >> Jadi kita akan pergi ke bagaimana objek pemetaan relasional memungkinkan 121 00:07:11,570 --> 00:07:16,668 Anda untuk melakukan hubungan ini dalam cara yang cukup mulus juga. 122 00:07:16,668 --> 00:07:17,660 Keren. 123 00:07:17,660 --> 00:07:20,290 Pertanyaan tentang fungsi dari apa yang kita akan membangun? 124 00:07:20,290 --> 00:07:22,850 125 00:07:22,850 --> 00:07:23,840 Keren. 126 00:07:23,840 --> 00:07:28,170 Jadi mari kita mulai dengan benar-benar menciptakan tabel database. 127 00:07:28,170 --> 00:07:33,190 >> Jadi ingat bahwa di CS50 Keuangan, Anda mengumpulkan meja untuk pengguna 128 00:07:33,190 --> 00:07:37,100 serta untuk saham dalam portofolio Anda. 129 00:07:37,100 --> 00:07:41,040 Jadi seperti yang telah disebutkan sebelumnya, apa yang kita gunakan dalam Laravel 130 00:07:41,040 --> 00:07:43,090 adalah sesuatu yang dikenal sebagai migrasi. 131 00:07:43,090 --> 00:07:48,570 Jadi, jika kita kembali ke Kode distribusi di sini, 132 00:07:48,570 --> 00:07:51,790 perintah pertama yang membantu yang Laravel menyediakan 133 00:07:51,790 --> 00:07:54,240 adalah perintah bermigrasi ini. 134 00:07:54,240 --> 00:07:59,220 Jadi kita bisa melakukan php tukang bermigrasi: membuat. 135 00:07:59,220 --> 00:08:01,760 Jadi ini memungkinkan kita untuk membuat migrasi. 136 00:08:01,760 --> 00:08:03,710 >> Dan kemudian kita akan ingin untuk membuat migrasi 137 00:08:03,710 --> 00:08:07,050 disebut create_posts_table, yang akan 138 00:08:07,050 --> 00:08:11,521 berada di tempat kita akan menjadi menyimpan posting blog kita. 139 00:08:11,521 --> 00:08:14,690 Dan Anda akan melihat di sini bahwa berjalan melalui beberapa kode yang sebenarnya 140 00:08:14,690 --> 00:08:17,580 menghasilkan file dengan cap waktu di atasnya. 141 00:08:17,580 --> 00:08:22,260 Jadi, jika kita pergi dan melihat database, kita akan melihat di bawah Migrasi 142 00:08:22,260 --> 00:08:24,830 bahwa itu menciptakan File kosong bagi kita yang 143 00:08:24,830 --> 00:08:30,100 memiliki kode boilerplate dengan nama bahwa kita ditentukan, membuat tabel posting. 144 00:08:30,100 --> 00:08:31,670 >> Dan memiliki dua fungsi di dalamnya. 145 00:08:31,670 --> 00:08:40,539 Up adalah apa yang kita ingin menjalankan ketika migrasi diterapkan ke database. 146 00:08:40,539 --> 00:08:46,380 Dan bawah adalah apa yang akan kita lakukan ketika kita ingin membalikkan migrasi. 147 00:08:46,380 --> 00:08:49,890 Jadi di sini mari kita mulai keluar dengan menulis migrasi ini. 148 00:08:49,890 --> 00:08:55,480 Jadi ada kelas membantu di Laravel disebut Schema. 149 00:08:55,480 --> 00:08:57,910 >> Jadi kita akan menjalankan skema :: buat. 150 00:08:57,910 --> 00:09:01,080 Dan kita akan membuat meja disebut posting. 151 00:09:01,080 --> 00:09:05,980 Dan di sini kita menerapkan ini menggunakan fungsi. 152 00:09:05,980 --> 00:09:11,010 Dan dalam sini, kita akan benar-benar menentukan isi meja kami. 153 00:09:11,010 --> 00:09:14,860 Kita akan membuat ID yang, yang merupakan auto-incrementing. 154 00:09:14,860 --> 00:09:19,850 155 00:09:19,850 --> 00:09:24,350 >> Selain itu, kita akan menciptakan lapangan yang 156 00:09:24,350 --> 00:09:27,060 merupakan judul posting blog kita. 157 00:09:27,060 --> 00:09:29,880 158 00:09:29,880 --> 00:09:36,950 Kami juga akan menciptakan lapangan untuk menyimpan teks dari posting blog kita. 159 00:09:36,950 --> 00:09:40,600 Dan akhirnya, kita akan untuk menyimpan beberapa cap waktu 160 00:09:40,600 --> 00:09:44,690 ketika posting kami diciptakan dan ketika itu diperbarui. 161 00:09:44,690 --> 00:09:46,240 Dan untuk turun, itu cukup sederhana. 162 00:09:46,240 --> 00:09:53,974 Semua kami ingin lakukan adalah penurunan tabel yang telah kita buat. 163 00:09:53,974 --> 00:09:54,930 >> Hebat Sekali. 164 00:09:54,930 --> 00:09:55,850 Ada pertanyaan? 165 00:09:55,850 --> 00:09:59,730 166 00:09:59,730 --> 00:10:07,110 Jadi sekarang jika kita pergi ke depan dan-- sebenarnya, host lokal, 167 00:10:07,110 --> 00:10:09,640 biarkan aku menghapus apa yang kita miliki sebelumnya. 168 00:10:09,640 --> 00:10:14,330 169 00:10:14,330 --> 00:10:15,190 Pergi ke Database. 170 00:10:15,190 --> 00:10:17,640 Aku akan menghapus apa yang kita miliki sebelumnya. 171 00:10:17,640 --> 00:10:22,870 Jatuhkan ini dan membuat database baru Blog50. 172 00:10:22,870 --> 00:10:24,930 Jadi sekarang apa yang ajaib Bagian sinilah kita 173 00:10:24,930 --> 00:10:28,760 dapat menerapkan migrasi ini secara langsung ke database menggunakan baris perintah 174 00:10:28,760 --> 00:10:29,290 Alat. 175 00:10:29,290 --> 00:10:35,100 Jadi jika kita melakukan php tukang bermigrasi, Anda akan melihat bahwa, hei. 176 00:10:35,100 --> 00:10:38,320 Ini menciptakan tabel migrasi, yang akan kita lihat di dalam sedikit, 177 00:10:38,320 --> 00:10:40,540 dan itu diterapkan migrasi pertama ini. 178 00:10:40,540 --> 00:10:43,860 179 00:10:43,860 --> 00:10:48,920 >> Jadi kita melihat Blog50, Anda akan melihat bahwa itu dibuat dua meja untuk kita. 180 00:10:48,920 --> 00:10:50,300 Pertama adalah tabel migrasi ini. 181 00:10:50,300 --> 00:10:54,130 Jadi, jika kita menelusuri ini, Anda akan melihat bahwa tabel ini cukup mudah. 182 00:10:54,130 --> 00:10:55,490 Ini hanya mengatakan bahwa, hei. 183 00:10:55,490 --> 00:10:58,960 Kami telah menerapkan migrasi ini. 184 00:10:58,960 --> 00:11:01,470 Kami kembali dan melihat posting. 185 00:11:01,470 --> 00:11:05,720 Anda akan melihat bahwa struktur adalah apa yang kita telah meminta itu. 186 00:11:05,720 --> 00:11:07,350 Kami memiliki ID auto-incrementing. 187 00:11:07,350 --> 00:11:10,450 Kami memiliki string untuk menyimpan judul, dan kolom teks 188 00:11:10,450 --> 00:11:11,450 untuk menyimpan konten. 189 00:11:11,450 --> 00:11:14,040 190 00:11:14,040 --> 00:11:14,706 Hebat Sekali. 191 00:11:14,706 --> 00:11:15,560 Keren. 192 00:11:15,560 --> 00:11:21,626 Pertanyaan tentang migrasi pekerjaan, bagaimana kita bisa menerapkannya? 193 00:11:21,626 --> 00:11:22,126 Tak Ada? 194 00:11:22,126 --> 00:11:23,600 Keren. 195 00:11:23,600 --> 00:11:26,630 Jadi sekarang kita akan pergi ke depan dan benar-benar membuat model. 196 00:11:26,630 --> 00:11:33,100 Jadi kita ingin membuat model tulisan yang menyimpan sebuah abstraksi dari database. 197 00:11:33,100 --> 00:11:41,040 Jadi daripada melakukan query MySQL langsung, kita akan buat. 198 00:11:41,040 --> 00:11:45,840 Jadi kita harus membuat folder di sini disebut model. 199 00:11:45,840 --> 00:11:48,905 Dan di dalam sini, kita akan membuat file bernama post.php. 200 00:11:48,905 --> 00:11:52,280 201 00:11:52,280 --> 00:11:54,550 >> Di dalam file PHP ini, kita akan membuat 202 00:11:54,550 --> 00:12:00,590 pos kelas yang meluas fasih. 203 00:12:00,590 --> 00:12:08,950 Fasih adalah nama dari ORM mesin yang Laravel menyediakan. 204 00:12:08,950 --> 00:12:12,799 Dan di sini, kita bisa berharap bahwa Anda benar-benar perlu untuk menulis beberapa kode. 205 00:12:12,799 --> 00:12:14,840 Kita akan menulis beberapa fungsi pembantu nanti. 206 00:12:14,840 --> 00:12:19,420 Tapi di luar kotak, ini akan sudah mengakui apa yang ada di database 207 00:12:19,420 --> 00:12:24,770 dan kita dapat mengakses, mengatakan, teks posting blog kita atau judul, 208 00:12:24,770 --> 00:12:29,230 dan menciptakan hal-hal secara langsung dengan cukup banyak tanpa kode apapun. 209 00:12:29,230 --> 00:12:31,110 >> Jadi itulah salah satu komponen ajaib. 210 00:12:31,110 --> 00:12:34,980 Dan angin setelah kelas ini lebih sepenuhnya matang, 211 00:12:34,980 --> 00:12:40,480 kami akan memasukkan informasi tentang apa itu terkait dengan, sehingga komentar. 212 00:12:40,480 --> 00:12:42,310 Juga membuat fungsi jadi kita benar-benar dapat 213 00:12:42,310 --> 00:12:46,340 langsung mendapatkan URL dari halaman posting blog. 214 00:12:46,340 --> 00:12:46,840 Keren. 215 00:12:46,840 --> 00:12:47,881 Pertanyaan tentang itu? 216 00:12:47,881 --> 00:12:51,140 217 00:12:51,140 --> 00:12:51,832 Tak Ada. 218 00:12:51,832 --> 00:12:54,100 Keren. 219 00:12:54,100 --> 00:12:57,860 >> Jadi sekarang setelah kita memiliki model kami, kami ingin membuat controller yang 220 00:12:57,860 --> 00:13:02,340 mampu berinteraksi dengan model ini, dan kemudian database. 221 00:13:02,340 --> 00:13:05,540 Jadi jika kita melihat pada BlogController, Anda akan 222 00:13:05,540 --> 00:13:08,490 melihat bahwa tidak ada banyak di sini sekarang. 223 00:13:08,490 --> 00:13:13,220 Semua ada adalah fungsi index yang menghasilkan halaman rumah, 224 00:13:13,220 --> 00:13:18,220 tapi tanpa apa-apa ada untuk menampilkan belum. 225 00:13:18,220 --> 00:13:20,560 >> Jadi fungsi pertama bahwa kita akan membuat 226 00:13:20,560 --> 00:13:25,790 adalah salah satu yang memungkinkan kita untuk membuat posting blog. 227 00:13:25,790 --> 00:13:30,540 Jadi kita akan mendeklarasikan Fungsi baru yang disebut NewPost. 228 00:13:30,540 --> 00:13:36,430 Dan di dalam sini hanya, kita akan untuk mengatur tata letak halaman ini 229 00:13:36,430 --> 00:13:41,850 menjadi membuat versi, jika Anda ingat dari CS50, 230 00:13:41,850 --> 00:13:48,020 template ini disebut blog.new, yang kita akan membuat dalam sedikit. 231 00:13:48,020 --> 00:13:53,170 >> Anda akan melihat di sini on line enam yang kita ditentukan variabel ini, tata letak. 232 00:13:53,170 --> 00:13:55,820 Dan jika kita melihat di folder Views, 233 00:13:55,820 --> 00:14:01,640 ada folder Layouts, yang termasuk file HTML yang sangat dasar. 234 00:14:01,640 --> 00:14:04,680 Dan catatan, Anda akan melihat bahwa kita memiliki wadah ini 235 00:14:04,680 --> 00:14:06,800 disini yang menghasilkan konten. 236 00:14:06,800 --> 00:14:09,460 Jadi dalam template kita apa yang kita akan lakukan 237 00:14:09,460 --> 00:14:16,180 adalah menciptakan apa yang akan menjadi diganti langsung dalam tata letak ini. 238 00:14:16,180 --> 00:14:20,060 >> Jadi kita mengatakan bahwa kita ingin membuat template disebut blog.new. 239 00:14:20,060 --> 00:14:23,790 Tapi di dalam Blog, ada belum template baru ini. 240 00:14:23,790 --> 00:14:26,910 Jadi kita akan membuat file bernama new.blade.php. 241 00:14:26,910 --> 00:14:29,860 Ini memberitahu Laravel yang PHP file ini harus 242 00:14:29,860 --> 00:14:31,720 akan diberikan dengan template engine blade. 243 00:14:31,720 --> 00:14:39,510 244 00:14:39,510 --> 00:14:42,630 Jadi ini adalah cukup File langsung. 245 00:14:42,630 --> 00:14:46,690 Ini akan menjadi bentuk dimana kita benar-benar menambahkan dalam posting blog. 246 00:14:46,690 --> 00:14:49,220 >> Jadi keajaiban di sini dari warisan adalah bahwa, hei. 247 00:14:49,220 --> 00:14:52,950 Kami ingin menentukan bahwa Bagian, bagian isi 248 00:14:52,950 --> 00:14:56,640 di sini, yang digambarkan olehsection danstop. 249 00:14:56,640 --> 00:15:02,260 Jadi apa yang ada di antara sini akan diganti ke dalam tata letak utama. 250 00:15:02,260 --> 00:15:07,000 Dan di sini apa yang ingin kita lakukan adalah sangat sederhana membuat file HTML baru. 251 00:15:07,000 --> 00:15:08,690 Mari kita tambahkan judul cepat. 252 00:15:08,690 --> 00:15:09,600 Menambahkan posting blog. 253 00:15:09,600 --> 00:15:12,110 254 00:15:12,110 --> 00:15:15,390 Dan di dalamnya, kami akan membuat formulir. 255 00:15:15,390 --> 00:15:19,197 >> Formulir ini akan memiliki tindakan. 256 00:15:19,197 --> 00:15:21,780 Dan ini akan menjadi sesuatu yang bahwa kita mengganti nanti, 257 00:15:21,780 --> 00:15:24,200 dan kita akan melihat bagaimana Routing cocok menjadi sini. 258 00:15:24,200 --> 00:15:33,600 Tapi kami hanya akan menentukan untuk saat ini bahwa ini pergi ke sebuah URL dengan rute 259 00:15:33,600 --> 00:15:34,860 dari createPost. 260 00:15:34,860 --> 00:15:38,200 261 00:15:38,200 --> 00:15:40,320 Dan maka ini akan memiliki metode pos. 262 00:15:40,320 --> 00:15:43,940 263 00:15:43,940 --> 00:15:47,590 Dalam sini, kita akan memiliki dua bidang. 264 00:15:47,590 --> 00:15:49,170 Div class = "bentuk-kelompok". 265 00:15:49,170 --> 00:15:55,806 >> Kami menggunakan perpustakaan Bootstrap CSS anggun disediakan oleh Twitter. 266 00:15:55,806 --> 00:15:57,720 Jadi kita akan membuat dua ini. 267 00:15:57,720 --> 00:16:01,700 268 00:16:01,700 --> 00:16:05,970 Jadi masukan pertama ini adalah akan menjadi judul. 269 00:16:05,970 --> 00:16:08,437 Nama sehingga input = "judul". 270 00:16:08,437 --> 00:16:09,270 Class = "formcontrol". 271 00:16:09,270 --> 00:16:13,540 272 00:16:13,540 --> 00:16:14,425 Type = "text". 273 00:16:14,425 --> 00:16:16,050 Aku akan menambahkan placeholder = "Judul". 274 00:16:16,050 --> 00:16:21,570 275 00:16:21,570 --> 00:16:26,140 >> Dan kemudian yang kedua adalah akan menjadi area teks. 276 00:16:26,140 --> 00:16:27,827 Nama = "content". 277 00:16:27,827 --> 00:16:28,660 Class = "formcontrol". 278 00:16:28,660 --> 00:16:33,402 279 00:16:33,402 --> 00:16:34,610 Dan placeholder = "Tulis di sini". 280 00:16:34,610 --> 00:16:42,030 281 00:16:42,030 --> 00:16:43,480 Di sana kami pergi. 282 00:16:43,480 --> 00:16:46,760 Akhirnya, kita akan menambahkan tombol kirim cepat. 283 00:16:46,760 --> 00:16:50,370 Type = "submit" class = "btn btn-utama". 284 00:16:50,370 --> 00:16:53,370 285 00:16:53,370 --> 00:16:55,340 Jadi ini semua fitur Bootstrap jadi 286 00:16:55,340 --> 00:16:58,510 bahwa ini bisa diletakkan dalam cara yang 287 00:16:58,510 --> 00:17:03,730 mangsa pengguna, bukan HTML telanjang. 288 00:17:03,730 --> 00:17:06,250 >> Jadi kita telah mendefinisikan controller di sini. 289 00:17:06,250 --> 00:17:08,930 Kami telah menetapkan pandangan yang sangat sederhana. 290 00:17:08,930 --> 00:17:12,339 Tapi apa yang hilang adalah jaringan ikat. 291 00:17:12,339 --> 00:17:15,420 Jadi pada titik ini, Laravel tidak tahu bagaimana 292 00:17:15,420 --> 00:17:18,312 kita akan benar-benar mengakses kontroler ini. 293 00:17:18,312 --> 00:17:20,270 Jadi ini didefinisikan dalam file bernama routes.php. 294 00:17:20,270 --> 00:17:22,780 295 00:17:22,780 --> 00:17:24,310 Dan sekarang, kita memiliki satu rute. 296 00:17:24,310 --> 00:17:29,060 Yang adalah ketika kita pergi ke jalan rumah untuk website ini, 297 00:17:29,060 --> 00:17:33,140 itu akan membuat controller indeks. 298 00:17:33,140 --> 00:17:38,880 Jadi di sini apa yang perlu kita lakukan adalah menerapkan rute baru bagi kita untuk membuat posting. 299 00:17:38,880 --> 00:17:41,910 >> Jadi kita menggunakan metode ini mendapatkan, yang menentukan 300 00:17:41,910 --> 00:17:48,650 bahwa ketika pengguna mencoba untuk mendapatkan ini page-- khusus 301 00:17:48,650 --> 00:17:52,850 pos slash page-- baru apa yang kita akan lakukan 302 00:17:52,850 --> 00:18:02,060 adalah menggunakan kontroler yang disebut Pos baru BlogController. 303 00:18:02,060 --> 00:18:03,460 Salah satu yang baru saja kita buat. 304 00:18:03,460 --> 00:18:08,090 Dan kemudian kita akan untuk alias sebagai NewPost. 305 00:18:08,090 --> 00:18:17,460 306 00:18:17,460 --> 00:18:19,850 Kita akan membuat yang lain fungsi dalam sedikit. 307 00:18:19,850 --> 00:18:23,520 Tapi apa di sini di bawah kunci "sebagai" yang 308 00:18:23,520 --> 00:18:28,195 kita bisa mengganti dalam Pisau kami template. 309 00:18:28,195 --> 00:18:32,390 310 00:18:32,390 --> 00:18:36,230 Jadi untuk saat ini, mari kita sebenarnya juga mengatakan rute. 311 00:18:36,230 --> 00:18:38,380 Jadi kita juga akan untuk membuat controller 312 00:18:38,380 --> 00:18:41,020 sehingga kita dapat membuat posting ini. 313 00:18:41,020 --> 00:18:46,940 Jadi, jika pengguna posting ke pos halaman slash baru, apa yang akan kita lakukan 314 00:18:46,940 --> 00:18:51,350 adalah menggunakan kontroler yang kita akan membuat lama 315 00:18:51,350 --> 00:18:56,160 disebut BlogController di createPost. 316 00:18:56,160 --> 00:19:01,929 Dan kita akan alias ini dengan sebagai createPost. 317 00:19:01,929 --> 00:19:03,380 Keren. 318 00:19:03,380 --> 00:19:05,811 >> Ada pertanyaan? 319 00:19:05,811 --> 00:19:06,310 Keren. 320 00:19:06,310 --> 00:19:09,790 Jadi mari kita jalankan apa yang kita miliki sejauh ini. 321 00:19:09,790 --> 00:19:16,930 Jadi jika kita melakukan php tukang melayani, kita akan melihat banyak kesalahan. 322 00:19:16,930 --> 00:19:20,385 Jadi sepertinya kita memiliki kesalahan sintaks pada rute baris 27. 323 00:19:20,385 --> 00:19:20,885 Ah. 324 00:19:20,885 --> 00:19:21,718 Hilang titik koma. 325 00:19:21,718 --> 00:19:24,900 326 00:19:24,900 --> 00:19:32,870 Jadi, jika kita pergi ke 8.000, Anda akan melihat apa-apa di sini belum. 327 00:19:32,870 --> 00:19:34,740 Jadi ini adalah home page default. 328 00:19:34,740 --> 00:19:37,730 >> Tetapi jika kita pergi ke posting memangkas baru, hey. 329 00:19:37,730 --> 00:19:40,425 Ini akan menjadi bentuk yang baru saja kita buat. 330 00:19:40,425 --> 00:19:42,550 Sekarang, kami belum diimplementasikan fungsi 331 00:19:42,550 --> 00:19:44,060 ketika kita menekan tombol Submit. 332 00:19:44,060 --> 00:19:47,110 Jadi jika kita klik Submit tombol, ia akan menjalankan kesalahan. 333 00:19:47,110 --> 00:19:49,840 Tapi kami akan kode yang sekarang, tepatnya apa yang kita 334 00:19:49,840 --> 00:19:54,840 ingin lakukan ketika pengguna menyerahkan formulir ini. 335 00:19:54,840 --> 00:19:55,770 >> Jadi mari kita lakukan itu. 336 00:19:55,770 --> 00:19:57,380 Kembali ke Controller berkas. 337 00:19:57,380 --> 00:20:00,180 Apa yang akan kita lakukan adalah menerapkan fungsi baru ini 338 00:20:00,180 --> 00:20:04,360 yang memungkinkan kita untuk membuat posting. 339 00:20:04,360 --> 00:20:07,370 340 00:20:07,370 --> 00:20:08,990 Menyatakan fungsi baru. 341 00:20:08,990 --> 00:20:11,527 Fungsi createPost publik. 342 00:20:11,527 --> 00:20:14,610 Dan fungsi ini akan menjadi sedikit lebih canggih dari apa 343 00:20:14,610 --> 00:20:15,559 kita miliki sebelumnya. 344 00:20:15,559 --> 00:20:18,350 Tapi Anda akan melihat di sini bahwa kita tidak akan benar-benar menulis SQL apapun. 345 00:20:18,350 --> 00:20:20,980 ORM, yang Fasih ORM, akan memungkinkan 346 00:20:20,980 --> 00:20:26,400 kita untuk melakukan hal ini dalam beberapa cara cara yang lebih elegan. 347 00:20:26,400 --> 00:20:29,140 >> Jadi kita akan membuat posting baru. 348 00:20:29,140 --> 00:20:34,120 Dan di sini kita instantiating objek baru 349 00:20:34,120 --> 00:20:38,080 dari model yang baru saja kita dibuat, model pos. 350 00:20:38,080 --> 00:20:44,450 Dan apa yang kita akan lakukan adalah mengatur Judul atribut ini menggunakan sesuatu 351 00:20:44,450 --> 00:20:47,380 yang kita dapatkan dari server. 352 00:20:47,380 --> 00:20:52,060 Jadi ini mirip dengan apa yang kita sebelumnya di CS50 Keuangan 353 00:20:52,060 --> 00:20:57,750 di mana kita akan lakukan, dengan menggunakan Super Global Posting mencari judul. 354 00:20:57,750 --> 00:21:01,600 >> Jadi Laravel menyediakan beberapa sanitasi dan yang lainnya menggunakan fungsi pembantu ini. 355 00:21:01,600 --> 00:21:07,610 Jadi kita lebih memilih untuk menggunakan ini sebagai gantinya dari bentuk mentah sangat mendasar ini dari PHP. 356 00:21:07,610 --> 00:21:17,430 Dan kemudian apa yang kita akan lakukan adalah mengatur isi ke Masukan mendapatkan konten. 357 00:21:17,430 --> 00:21:20,429 358 00:21:20,429 --> 00:21:22,720 Kami benar-benar akan membungkus ini dalam fungsi membantu 359 00:21:22,720 --> 00:21:31,820 PHP yang menyediakan disebut nl2br, yang ternyata baru baris, nls, ke brs, istirahat, 360 00:21:31,820 --> 00:21:35,822 sehingga kita benar-benar dapat memiliki paragraf yang berbeda di dalamnya. 361 00:21:35,822 --> 00:21:38,030 Dan akhirnya apa yang kita akan lakukan adalah menyimpan posting ini. 362 00:21:38,030 --> 00:21:41,686 Jadi kita sebut fungsi menghemat model ini. 363 00:21:41,686 --> 00:21:43,800 Kita akan menyimpan pos. 364 00:21:43,800 --> 00:21:49,970 Dan akhirnya apa yang akan kita lakukan adalah mengarahkan pengguna khusus 365 00:21:49,970 --> 00:21:55,060 dengan rute yang kita akan membuat lama, alias oleh viewPost. 366 00:21:55,060 --> 00:22:00,435 Dan kita akan lulus dalam argumen id, menjadi id dari posting baru ini. 367 00:22:00,435 --> 00:22:04,280 368 00:22:04,280 --> 00:22:05,640 >> Hebat Sekali. 369 00:22:05,640 --> 00:22:09,090 Jadi jika kita benar-benar pergi dan menjalankan ini. 370 00:22:09,090 --> 00:22:11,370 Kita akan menambahkan posting baru. 371 00:22:11,370 --> 00:22:15,930 Mari kita mengatakan ini adalah seminar 50. 372 00:22:15,930 --> 00:22:17,620 Dan katakanlah, yakin. 373 00:22:17,620 --> 00:22:18,240 Asdl. 374 00:22:18,240 --> 00:22:18,740 Bodo Amat. 375 00:22:18,740 --> 00:22:20,320 Beberapa jenis konten. 376 00:22:20,320 --> 00:22:21,180 Dan Submit itu. 377 00:22:21,180 --> 00:22:23,850 Dan kita akan melihat bahwa, hey. rute tidak didefinisikan. 378 00:22:23,850 --> 00:22:32,340 Tetapi jika kita melihat pada phpMyAdmin dan mencari apakah fungsi kita 379 00:22:32,340 --> 00:22:34,370 melakukan apa-apa. 380 00:22:34,370 --> 00:22:36,670 Lihatlah Blog50 posting. 381 00:22:36,670 --> 00:22:37,720 Kita akan melihat bahwa, hei. 382 00:22:37,720 --> 00:22:43,530 Bahkan, kita hanya membuat blog yang posting dengan cap waktu yang ditentukan. 383 00:22:43,530 --> 00:22:46,600 384 00:22:46,600 --> 00:22:51,630 >> Jadi sekarang mari kita kembali dan benar-benar membuat fungsi ini di controller kita, 385 00:22:51,630 --> 00:22:54,790 khusus controller viewPost. 386 00:22:54,790 --> 00:23:00,290 ViewPost fungsi sehingga masyarakat. 387 00:23:00,290 --> 00:23:04,070 Jadi di sini yang akan kita lakukan, bukan memiliki tanda kurung kosong, 388 00:23:04,070 --> 00:23:08,800 kita akan ingin lulus dalam ID posting yang kita buat. 389 00:23:08,800 --> 00:23:12,800 Dan dari sini apa yang akan kita lakukan sebenarnya query database untuk itu. 390 00:23:12,800 --> 00:23:15,140 >> Jadi jika kita posting, ada fungsi yang disebut 391 00:23:15,140 --> 00:23:18,860 Cari yang memungkinkan kita untuk query dengan ID. 392 00:23:18,860 --> 00:23:22,110 Secara khusus, sebenarnya, kita akan menggunakan versi alternatif ini disebut 393 00:23:22,110 --> 00:23:27,880 Cari atau Gagal, yang memungkinkan kita untuk berhenti dari fungsi ini, 394 00:23:27,880 --> 00:23:34,700 melemparkan pengecualian jika ID kita lulus dalam tidak ada. 395 00:23:34,700 --> 00:23:37,500 Dan kemudian kita akan melakukan sesuatu mirip dengan apa yang kita lakukan sebelumnya 396 00:23:37,500 --> 00:23:41,100 di mana kita mengatur konten halaman ini menjadi 397 00:23:41,100 --> 00:23:47,950 versi diberikan pandang baru ini yang kita akan membuat, blog.view. 398 00:23:47,950 --> 00:23:51,030 >> Dan kita akan masuk ke dalam itu-- hanya seperti di CS50 render 399 00:23:51,030 --> 00:23:56,645 function-- kamus variabel. 400 00:23:56,645 --> 00:23:59,860 401 00:23:59,860 --> 00:24:04,620 Kunci dari array asosiatif ini menjadi variabel dalam template. 402 00:24:04,620 --> 00:24:06,830 Jadi kita akan melakukan posting posting. 403 00:24:06,830 --> 00:24:12,474 Jadi secara tidak langsung lewat pos yang kita sudah tanya dari database. . 404 00:24:12,474 --> 00:24:14,390 Sekarang apa yang kita akan lakukan adalah membuat tampilan ini 405 00:24:14,390 --> 00:24:17,560 sehingga kita benar-benar dapat melihat posting blog yang telah kami bangun. 406 00:24:17,560 --> 00:24:20,280 >> Jadi kita akan membuat file bernama view.blade.php. 407 00:24:20,280 --> 00:24:25,870 408 00:24:25,870 --> 00:24:29,640 Jadi dalam template ini, apa yang kita akan lakukan 409 00:24:29,640 --> 00:24:39,700 disatukan halaman sederhana yang memungkinkan kita untuk menampilkan konten. 410 00:24:39,700 --> 00:24:44,280 Jadi kita melakukan bagian, itu sebelum konten. 411 00:24:44,280 --> 00:24:46,800 Berhenti. 412 00:24:46,800 --> 00:24:53,920 Dan apa yang kita akan yang harus dilakukan dalam sini 413 00:24:53,920 --> 00:24:56,930 menulis beberapa HTML untuk menampilkan halaman ini. 414 00:24:56,930 --> 00:25:03,590 >> Jadi kita akan membungkusnya dengan mewah elemen HTML5 baru yang disebut Pasal. 415 00:25:03,590 --> 00:25:05,790 Dan di sini, kita akan memiliki header di mana 416 00:25:05,790 --> 00:25:12,190 kita akan hanya memiliki h1, yang meliputi judul posting. 417 00:25:12,190 --> 00:25:17,120 Jadi di sini, jika kita melihat ini notasi penjepit keriting ganda, 418 00:25:17,120 --> 00:25:21,690 ini akan melakukan dasarnya PHP gema judul posting. 419 00:25:21,690 --> 00:25:25,630 Jadi itu adalah singkatan bermanfaat bahwa Laravel memberikan kita. 420 00:25:25,630 --> 00:25:31,070 Jadi kita akan menggunakan notasi ini sebagai gantinya. 421 00:25:31,070 --> 00:25:40,220 >> Dan di sini, kita akan juga mencetak isi dari itu. 422 00:25:40,220 --> 00:25:43,480 Dan di sini, kita akan untuk melakukan isi posting. 423 00:25:43,480 --> 00:25:46,514 424 00:25:46,514 --> 00:25:50,660 Dan turun di bawah apa yang kita akan lakukan adalah membuat footer. 425 00:25:50,660 --> 00:25:57,690 Dan di footer, kita akan tampilan pertama ketika ini diposting. 426 00:25:57,690 --> 00:26:01,320 Jadi ini telah diposting di, dibuat di. 427 00:26:01,320 --> 00:26:07,996 >> Dan Laravel menggunakan benar-benar baik tanggal perpustakaan yang disebut Carbon. 428 00:26:07,996 --> 00:26:11,120 Jadi kita benar-benar bisa melakukan sesuatu yang disebut difforHumans, yang Anda lihat sebelumnya. 429 00:26:11,120 --> 00:26:14,360 Ketika kita diposting. itu akan mengatakan, seperti, lima detik lalu. 430 00:26:14,360 --> 00:26:16,860 Jadi ini adalah benar-benar baik fungsi Laravel. 431 00:26:16,860 --> 00:26:19,469 432 00:26:19,469 --> 00:26:21,385 Dan akhirnya, kita akan untuk menutup footer ini. 433 00:26:21,385 --> 00:26:24,900 434 00:26:24,900 --> 00:26:31,450 >> Jadi sekarang jika kita kembali ke Halaman kita akan 435 00:26:31,450 --> 00:26:34,490 untuk melihat apa-apa di sini belum karena kami belum dikodekan sampai halaman rumah. 436 00:26:34,490 --> 00:26:40,962 Tetapi jika kita pergi ke posting slash satu, kita akan melihat pengecualian. 437 00:26:40,962 --> 00:26:42,670 Apakah ada yang tahu mengapa kita melihat pengecualian? 438 00:26:42,670 --> 00:26:44,516 Apa yang kita hilang? 439 00:26:44,516 --> 00:26:45,290 Ada gagasan? 440 00:26:45,290 --> 00:26:48,050 441 00:26:48,050 --> 00:26:49,790 Jadi apa yang kita lakukan sebelumnya untuk kita benar-benar 442 00:26:49,790 --> 00:26:52,285 untuk menentukan bagaimana kita bisa kontroler tertentu? 443 00:26:52,285 --> 00:26:54,895 444 00:26:54,895 --> 00:26:55,770 >> SPEAKER 1: Rute? 445 00:26:55,770 --> 00:26:56,519 ERIC Ouyang: Ya. 446 00:26:56,519 --> 00:26:58,070 Jadi kita masih harus menentukan rute. 447 00:26:58,070 --> 00:26:59,794 Jadi kita kembali ke sini untuk routes.php. 448 00:26:59,794 --> 00:27:01,710 Anda akan melihat kami yang belum benar-benar didefinisikan 449 00:27:01,710 --> 00:27:05,010 bagaimana kita akan mendapatkan ke controller ini. 450 00:27:05,010 --> 00:27:06,780 Jadi sekarang kita akan menentukan rute ini. 451 00:27:06,780 --> 00:27:09,280 Ini cukup mudah, mirip dengan apa yang kita lakukan sebelumnya. 452 00:27:09,280 --> 00:27:13,910 Tapi apa yang akan kita perhatikan di sini adalah bahwa kita akan memiliki placeholder. 453 00:27:13,910 --> 00:27:18,730 >> Jadi jika kita melakukan route.get pasca slash ID. 454 00:27:18,730 --> 00:27:24,290 Jadi ID sekarang adalah apa yang akan diteruskan ke controller. 455 00:27:24,290 --> 00:27:27,820 Ini akan menggunakan controller yang kita hanya 456 00:27:27,820 --> 00:27:33,560 dibuat, BlogController di viewPost. 457 00:27:33,560 --> 00:27:36,420 Dan kita akan alias ini sebagai viewPost. 458 00:27:36,420 --> 00:27:46,544 459 00:27:46,544 --> 00:27:47,490 Hebat Sekali. 460 00:27:47,490 --> 00:27:49,470 Jadi sekarang kita akan membuat rute ini. 461 00:27:49,470 --> 00:27:52,100 >> Jadi jika kita pergi ke sini dan refresh halaman ini, 462 00:27:52,100 --> 00:27:54,410 kita sebenarnya memang harus posting blog baru. 463 00:27:54,410 --> 00:27:57,710 Jadi ini adalah apa yang kita buat sebelumnya. 464 00:27:57,710 --> 00:28:01,320 Sangat halaman sederhana, namun akan menampilkan posting blog yang baru saja kita buat. 465 00:28:01,320 --> 00:28:04,210 466 00:28:04,210 --> 00:28:04,760 Keren. 467 00:28:04,760 --> 00:28:08,880 Dan jika kita benar-benar pergi melalui seluruh proses membuat posting blog baru, 468 00:28:08,880 --> 00:28:11,700 kita akan melihat bahwa segala sesuatu pengalihan benar. 469 00:28:11,700 --> 00:28:12,950 Jika saya mengatakan, "Hi. 470 00:28:12,950 --> 00:28:15,710 Saya Jonathan Tan. " 471 00:28:15,710 --> 00:28:18,550 Katakanlah, "Ini adalah posting blog saya." 472 00:28:18,550 --> 00:28:22,830 Dan Kirim itu, hal ini akan menciptakan ini posting blog baru dengan ID 2, 473 00:28:22,830 --> 00:28:28,920 yang bertahap dari apa yang kita punya sebelumnya dan menampilkannya dengan benar. 474 00:28:28,920 --> 00:28:30,760 Mengagumkan. 475 00:28:30,760 --> 00:28:32,930 >> Ada pertanyaan? 476 00:28:32,930 --> 00:28:33,430 Iya Nih? 477 00:28:33,430 --> 00:28:36,537 >> SPEAKER 2: Apakah Laravel menangani sanitasi dan semuanya untuk Anda? 478 00:28:36,537 --> 00:28:37,245 ERIC Ouyang: Ya. 479 00:28:37,245 --> 00:28:42,990 Jadi ketika kita melihat sebelumnya ketika kami masukan usus usus bisa, 480 00:28:42,990 --> 00:28:47,720 yang sanitates SQL setiap suntikan dan yang lainnya 481 00:28:47,720 --> 00:28:51,660 bahwa kita mungkin ingin melakukan jika kami pengguna berbahaya dari situs web. 482 00:28:51,660 --> 00:28:54,115 Jadi Laravel menangani banyak itu di belakang layar. 483 00:28:54,115 --> 00:28:57,030 Pertanyaan yang bagus. 484 00:28:57,030 --> 00:29:00,390 >> Jadi mari kita lihat di halaman rumah. 485 00:29:00,390 --> 00:29:03,220 486 00:29:03,220 --> 00:29:06,790 Jadi, jika kita pertama kali kembali ke controller untuk halaman rumah, 487 00:29:06,790 --> 00:29:08,740 Anda akan melihat bahwa itu tidak berbuat banyak di sini. 488 00:29:08,740 --> 00:29:11,620 Anda akan melihat bahwa kita tidak melewati ke controller ini 489 00:29:11,620 --> 00:29:13,830 sesuatu yang sangat membantu. 490 00:29:13,830 --> 00:29:16,660 Hanya saja file indeks ini. 491 00:29:16,660 --> 00:29:18,770 >> Jadi mari kita masuk ke sesuatu ini bermanfaat. 492 00:29:18,770 --> 00:29:21,450 Dan secara khusus, kami akan lulus dalam posting. 493 00:29:21,450 --> 00:29:28,740 Dan Laravel memungkinkan kita untuk melakukan posting semua, yang 494 00:29:28,740 --> 00:29:30,625 akan memungkinkan kita untuk mendapatkan semua posting. 495 00:29:30,625 --> 00:29:33,160 496 00:29:33,160 --> 00:29:35,730 Sekarang jika kita kembali ke index.php, Anda akan melihat, hey. 497 00:29:35,730 --> 00:29:37,060 Tidak ada di sini belum. 498 00:29:37,060 --> 00:29:41,290 Tapi apa yang kita ingin lakukan di sini sebenarnya iterate melalui, 499 00:29:41,290 --> 00:29:46,420 melakukan loop foreach atas posting yang memungkinkan kita untuk mencetak tulisan. 500 00:29:46,420 --> 00:29:53,180 >> Posting begitu foreach sebagai posting, apa yang ingin kita lakukan 501 00:29:53,180 --> 00:29:57,252 adalah mencetak konten dari posting blog. 502 00:29:57,252 --> 00:30:00,210 Tapi satu hal yang akan Anda perhatikan adalah bahwa kita benar-benar menulis sebagian besar kode yang 503 00:30:00,210 --> 00:30:01,370 sudah, di view.blade.php. 504 00:30:01,370 --> 00:30:04,070 505 00:30:04,070 --> 00:30:08,640 Jadi apa yang akan kita benar-benar lakukan adalah menggunakan fitur bermanfaat yang bagus Blade 506 00:30:08,640 --> 00:30:11,300 dan faktor luar kode umum ini. 507 00:30:11,300 --> 00:30:12,570 Jadi kita pergi ke sini. 508 00:30:12,570 --> 00:30:16,210 >> Kita akan mengambil konten ini di sini, dan apa yang akan kita lakukan 509 00:30:16,210 --> 00:30:18,170 adalah membuat folder baru. 510 00:30:18,170 --> 00:30:20,364 Mari kita sebut saja parsial. 511 00:30:20,364 --> 00:30:22,530 Dan di sini, kita akan untuk membuat post.blade.php a. 512 00:30:22,530 --> 00:30:26,570 513 00:30:26,570 --> 00:30:33,100 Jadi di sini, kami keluar faktor jalan di yang kita ingin menampilkan posting ini. 514 00:30:33,100 --> 00:30:38,690 Dan di sini yang akan kita lakukan bukan benar-benar memiliki HTML yang langsung, 515 00:30:38,690 --> 00:30:41,530 kita akan menggunakan direktif ini disebut termasuk blog.partials.post. 516 00:30:41,530 --> 00:30:45,210 517 00:30:45,210 --> 00:30:50,635 >> Dan apa yang akan kita lakukan di sini adalah lulus dalam posting halaman. 518 00:30:50,635 --> 00:30:57,076 519 00:30:57,076 --> 00:31:01,050 Jadi sekarang jika kita kembali ke sini, kita akan melihat bahwa fungsi ini masih 520 00:31:01,050 --> 00:31:01,550 sama. 521 00:31:01,550 --> 00:31:05,140 Tapi sekarang kita punya ini faktor luar kode, HTML ini. 522 00:31:05,140 --> 00:31:07,070 Jadi kita bisa menggunakannya di Index. 523 00:31:07,070 --> 00:31:09,090 Jadi di sini, ini sangat mudah. 524 00:31:09,090 --> 00:31:17,870 Semua yang kita lakukan adalah termasuk blog.partials.post dan berbagai. 525 00:31:17,870 --> 00:31:20,845 Dan tempat untuk sebelumnya, kami melakukan posting posting. 526 00:31:20,845 --> 00:31:23,830 527 00:31:23,830 --> 00:31:28,182 >> Jadi sekarang jika kita kembali ke halaman rumah, kita akan melihat bahwa, hei. 528 00:31:28,182 --> 00:31:30,515 Kami memiliki daftar semua posting blog yang kita miliki sebelumnya. 529 00:31:30,515 --> 00:31:34,640 530 00:31:34,640 --> 00:31:37,700 Kita mungkin ingin menambahkan beberapa "jika" kondisi dan "lain" kondisi 531 00:31:37,700 --> 00:31:39,979 sehingga jika kita tidak memiliki apapun di blog, 532 00:31:39,979 --> 00:31:41,520 kita ingin menampilkan sesuatu yang bermanfaat. 533 00:31:41,520 --> 00:31:42,570 Seperti, hey. 534 00:31:42,570 --> 00:31:44,340 Tidak ada konten belum di blog. 535 00:31:44,340 --> 00:31:47,670 Dan jika kalian benar-benar melihat kode distribusi pada GitHub, 536 00:31:47,670 --> 00:31:50,100 Anda akan melihat sebuah contoh bagaimana kita melakukannya. 537 00:31:50,100 --> 00:31:52,770 538 00:31:52,770 --> 00:31:54,110 >> Keren. 539 00:31:54,110 --> 00:31:54,890 Ada pertanyaan? 540 00:31:54,890 --> 00:31:55,510 Iya Nih. 541 00:31:55,510 --> 00:31:57,468 >> SPEAKER 2: Saya kira hanya pertanyaan mendasar. 542 00:31:57,468 --> 00:31:59,480 Kembali pada rute. 543 00:31:59,480 --> 00:32:00,230 ERIC Ouyang: Ya. 544 00:32:00,230 --> 00:32:01,935 Jika kita melihat pada rute. 545 00:32:01,935 --> 00:32:06,018 >> SPEAKER 2: Mana yang uses.blogcontroller di buat pos, 546 00:32:06,018 --> 00:32:07,560 apa yang mengarahkan kita untuk? 547 00:32:07,560 --> 00:32:08,310 ERIC Ouyang: Ya. 548 00:32:08,310 --> 00:32:08,550 Ya. 549 00:32:08,550 --> 00:32:09,716 >> SPEAKER 2: Atau apa yang itu-- 550 00:32:09,716 --> 00:32:12,620 ERIC Ouyang: Jadi, kita lihat, katakan misalnya, dengan ini di sini. 551 00:32:12,620 --> 00:32:17,190 Bagian pertama adalah aktual URL bahwa pengguna akan pergi ke. 552 00:32:17,190 --> 00:32:19,930 Dan array ini di sini, array asosiatif, mendefinisikan 553 00:32:19,930 --> 00:32:24,520 bagaimana kita ingin memiliki Aplikasi tindakan dalam menanggapi hal itu. 554 00:32:24,520 --> 00:32:29,090 Jadi gunakan adalah controller, fungsi yang kita 555 00:32:29,090 --> 00:32:31,610 ingin menelepon ketika pengguna pergi ke URL ini. 556 00:32:31,610 --> 00:32:35,190 Jadi viewPost di sini adalah fungsi yang kita definisikan dalam 557 00:32:35,190 --> 00:32:36,100 dari BlogController-- 558 00:32:36,100 --> 00:32:37,160 >> SPEAKER 2: Saya melihat. 559 00:32:37,160 --> 00:32:39,368 >> ERIC Ouyang: --so kita bahwa benar-benar dapat membuat tampilan, 560 00:32:39,368 --> 00:32:42,590 melakukan beberapa perhitungan, berinteraksi dengan database SQL. 561 00:32:42,590 --> 00:32:43,560 >> SPEAKER 2: OK. 562 00:32:43,560 --> 00:32:46,960 >> ERIC Ouyang: Dan kemudian yang lain bagian, "sebagai" adalah alias yang kita gunakan. 563 00:32:46,960 --> 00:32:50,714 Jadi jika kita melihat ketika kami menciptakan bentuk, 564 00:32:50,714 --> 00:32:52,380 Anda akan melihat URL yang :: routecreatePost. 565 00:32:52,380 --> 00:32:55,000 566 00:32:55,000 --> 00:32:58,330 Jadi pengganti di aktual URL sehingga kita tidak sulit 567 00:32:58,330 --> 00:33:02,940 coding ini sehingga kami bisa mengubahnya sekali, mengatakan jika kita ingin mengubah nama. 568 00:33:02,940 --> 00:33:06,055 Alih-alih pos slash baru, kami ingin lakukan seperti, p 569 00:33:06,055 --> 00:33:09,490 memangkas baru hanya untuk membersihkan up URL kita sedikit. 570 00:33:09,490 --> 00:33:14,740 Kami akan mengubahnya di satu tempat yang agak daripada di semua file yang berbeda. 571 00:33:14,740 --> 00:33:15,451 >> Keren. 572 00:33:15,451 --> 00:33:15,950 Itu bagus. 573 00:33:15,950 --> 00:33:20,070 Jadi sekarang kita memiliki sangat Platform blog dasar. 574 00:33:20,070 --> 00:33:24,260 Kita mungkin ingin menambahkan tombol sehingga bahwa kita benar-benar dapat membuat posting baru. 575 00:33:24,260 --> 00:33:27,850 Jadi, jika kita melihat di Layout Guru, 576 00:33:27,850 --> 00:33:31,280 kami memiliki bagian yang disebut header Kanan bahwa kita baru saja ditetapkan di atas. 577 00:33:31,280 --> 00:33:34,820 Jadi kita bisa menambahkan tombol untuk bagian atas header. 578 00:33:34,820 --> 00:33:43,950 >> Jadi jika kita pergi ke index.blade.php, sebenarnya lakukan adalah menentukan apa yang terjadi di dalam sini. 579 00:33:43,950 --> 00:33:46,970 Jadi bagian Header Kanan ini, apa yang kita akan lakukan 580 00:33:46,970 --> 00:33:55,240 adalah menambahkan tombol untuk pergi ke URL yang didefinisikan oleh rute pos baru. 581 00:33:55,240 --> 00:33:58,270 582 00:33:58,270 --> 00:34:01,660 Hanya untuk membersihkannya dan membuat itu cantik dan semua Bootstrap, 583 00:34:01,660 --> 00:34:04,630 kita akan membuat ini tombol default. 584 00:34:04,630 --> 00:34:07,794 Mari kita membuatnya besar untuk bersenang-senang. 585 00:34:07,794 --> 00:34:09,969 >> Dan di dalamnya, kita bisa menempatkan beberapa teks. 586 00:34:09,969 --> 00:34:14,030 Tapi apa Bootstrap memberikan adalah glyphicons. 587 00:34:14,030 --> 00:34:17,840 Jadi kita benar-benar dapat menambahkan bahwa pensil bagus yang kita lihat sebelumnya. 588 00:34:17,840 --> 00:34:20,570 589 00:34:20,570 --> 00:34:21,781 Glyphicon. 590 00:34:21,781 --> 00:34:22,489 Glyphicon-pensil. 591 00:34:22,489 --> 00:34:25,449 592 00:34:25,449 --> 00:34:35,340 Jadi ini akan memungkinkan kita untuk menempatkan di ikon bukan teks. 593 00:34:35,340 --> 00:34:38,960 Sekarang jika kita berhenti, ini akan menentukan bagian ini. 594 00:34:38,960 --> 00:34:39,460 Dan, hey. 595 00:34:39,460 --> 00:34:45,000 Kami memiliki tombol yang bagus yang menghubungkan kita langsung ke menambahkan halaman posting blog. 596 00:34:45,000 --> 00:34:46,659 >> Jadi kita memiliki blog yang cukup sederhana. 597 00:34:46,659 --> 00:34:49,710 Kita bisa menambahkan hal itu. 598 00:34:49,710 --> 00:34:53,650 Tapi apa yang biasanya kita harapkan dari blog yang berkomentar. 599 00:34:53,650 --> 00:34:57,340 Jadi itu benar-benar penting bagi kita untuk memiliki, mengatakan, jika orang lain mengunjungi website 600 00:34:57,340 --> 00:35:00,620 dan benar-benar menyukai posting yang mereka dapat terlibat dalam diskusi 601 00:35:00,620 --> 00:35:03,100 dengan orang lain yang mengunjungi halaman. 602 00:35:03,100 --> 00:35:07,050 Jadi kita akan pergi dan membuat tabel database baru dan model baru 603 00:35:07,050 --> 00:35:12,220 sehingga kita dapat mengaitkan komentar dengan posting. 604 00:35:12,220 --> 00:35:17,370 >> Jadi langkah pertama, sama seperti sebelumnya, adalah bahwa kita perlu menjalankan migrasi. 605 00:35:17,370 --> 00:35:21,982 Jadi seperti sebelumnya, kita lakukan php tukang bermigrasi: membuat. 606 00:35:21,982 --> 00:35:24,440 Dan kita akan membuat satu disebut create_comments_table. 607 00:35:24,440 --> 00:35:29,520 608 00:35:29,520 --> 00:35:36,080 Hal ini akan membuat file yang memiliki migrasi baru. 609 00:35:36,080 --> 00:35:40,170 Dan kita akan, seperti sebelumnya, mendefinisikan tabel baru. 610 00:35:40,170 --> 00:35:42,773 Jadi Skema :: membuat tabel bernama komentar. 611 00:35:42,773 --> 00:35:47,410 612 00:35:47,410 --> 00:35:48,430 Fungsi ini di sini. 613 00:35:48,430 --> 00:35:51,620 Dan di dalam tabel ini apa kita akan lakukan adalah pertama, 614 00:35:51,620 --> 00:35:54,260 seperti sebelumnya, menetapkan ID. 615 00:35:54,260 --> 00:35:56,552 Increment ID. 616 00:35:56,552 --> 00:36:05,440 >> Kita akan memungkinkan pengguna untuk menghubungkan nama mereka dengan komentar tertentu. 617 00:36:05,440 --> 00:36:10,080 Kita akan memiliki beberapa konten yang sejalan dengan ini, isi teks. 618 00:36:10,080 --> 00:36:13,580 619 00:36:13,580 --> 00:36:15,910 Dan di sini apa yang kita akan lakukan adalah sesuatu yang berbeda. 620 00:36:15,910 --> 00:36:23,620 Kita akan membuat integer yang disebut post_id yang 621 00:36:23,620 --> 00:36:32,100 akan menandakan apa posting komentar tertentu berjalan dengan. 622 00:36:32,100 --> 00:36:35,410 >> Selain itu, kami benar-benar akan menetapkan batasan kunci asing ini. 623 00:36:35,410 --> 00:36:37,750 Jadi MySQL akan menegakkan itu. 624 00:36:37,750 --> 00:36:39,840 Kami tidak mencoba untuk menetapkan nomor komentar 625 00:36:39,840 --> 00:36:44,440 5 untuk mengirim 5.000 jika kita belum memiliki 5.000 posting di atasnya. 626 00:36:44,440 --> 00:36:50,240 Jadi apa yang kita lakukan di sini, kita lakukan post_id asing 627 00:36:50,240 --> 00:37:02,046 akan berhubungan dengan bidang ID dari posting meja. 628 00:37:02,046 --> 00:37:05,900 Dan kita benar-benar akan melakukan sesuatu lain membantu, adalah onDelete. 629 00:37:05,900 --> 00:37:11,180 >> Jadi jika kita menghapus beberapa posting dari database, 630 00:37:11,180 --> 00:37:15,507 bahwa kita ingin kaskade menghapus komentar juga. 631 00:37:15,507 --> 00:37:18,090 Karena itu tidak sangat membantu bagi kita untuk memiliki komentar pada posting 632 00:37:18,090 --> 00:37:19,900 yang tidak ada. 633 00:37:19,900 --> 00:37:23,764 Dan akhirnya, seperti sebelumnya, kami akan mengatur perangko waktu untuk hal ini. 634 00:37:23,764 --> 00:37:28,690 635 00:37:28,690 --> 00:37:33,510 Dan seperti sebelumnya, kita akan memiliki migrasi sebaliknya menjadi 636 00:37:33,510 --> 00:37:37,920 menjatuhkan tabel komentar. 637 00:37:37,920 --> 00:37:40,070 >> Jadi sekarang jika kita kembali di sini, kita akan 638 00:37:40,070 --> 00:37:43,110 untuk menjalankan migrasi ini, tukang bermigrasi. 639 00:37:43,110 --> 00:37:46,400 Dan sekarang itu diterapkan ini migrasi yang baru saja kita buat. 640 00:37:46,400 --> 00:37:50,080 Jadi jika kita melihat phpMyAdmin, kita lakukan, pada kenyataannya, sekarang 641 00:37:50,080 --> 00:37:53,210 memiliki tabel komentar yang memiliki Struktur yang baru saja kita ditentukan. 642 00:37:53,210 --> 00:37:56,900 643 00:37:56,900 --> 00:37:59,610 Jadi seperti sebelumnya, kami akan menciptakan model baru 644 00:37:59,610 --> 00:38:04,450 abstrak tabel SQL yang baru saja kita buat. 645 00:38:04,450 --> 00:38:05,450 >> Jadi mari kita Tambah file baru. 646 00:38:05,450 --> 00:38:06,908 Kita akan menyebutnya comment.php. 647 00:38:06,908 --> 00:38:10,160 648 00:38:10,160 --> 00:38:15,490 Dan ini benar-benar akan menjadi cukup langsung dengan sedikit perubahan 649 00:38:15,490 --> 00:38:17,520 dari apa yang kita miliki sebelumnya. 650 00:38:17,520 --> 00:38:22,790 Jadi kelas Komentar meluas Fasih. 651 00:38:22,790 --> 00:38:25,930 Dan apa yang kita akan lakukan di sini adalah mendefinisikan 652 00:38:25,930 --> 00:38:31,360 fungsi yang merupakan hubungan dengan model lainnya. 653 00:38:31,360 --> 00:38:39,250 Jadi kita akan memiliki fungsi pos di sini yang mengembalikan hubungan ini. 654 00:38:39,250 --> 00:38:43,330 Jadi kita menentukan bahwa ini milik posting, 655 00:38:43,330 --> 00:38:49,200 mengatakan bahwa ada satu posting bahwa komentar ini milik. 656 00:38:49,200 --> 00:38:53,917 >> Ini benar-benar harus P modal untuk model. 657 00:38:53,917 --> 00:38:56,500 Dan sekarang hanya pada flip lain sisi, kita harus mengatakan bahwa, hei. 658 00:38:56,500 --> 00:38:58,160 Posting memiliki komentar. 659 00:38:58,160 --> 00:39:03,030 Jadi apa yang akan kita lakukan adalah mendefinisikan fungsi komentar publik. 660 00:39:03,030 --> 00:39:07,100 661 00:39:07,100 --> 00:39:13,620 Dan di sini dikembalikan ini memiliki banyak Komentar. 662 00:39:13,620 --> 00:39:16,630 663 00:39:16,630 --> 00:39:22,010 Jadi sekarang ajaib ketika kita memiliki posting, kita bisa mendapatkan komentar atribut 664 00:39:22,010 --> 00:39:25,615 dan itu akan mengisinya dengan informasi dari database. 665 00:39:25,615 --> 00:39:32,950 666 00:39:32,950 --> 00:39:38,220 >> Jadi mari kita benar-benar pergi melalui dan menambahkan fitur baru ke file pandangan kami 667 00:39:38,220 --> 00:39:43,600 sehingga kita bisa baik tampilan dan menciptakan komentar. 668 00:39:43,600 --> 00:39:54,010 669 00:39:54,010 --> 00:39:56,865 Jadi kita akan menentukan bagian baru. 670 00:39:56,865 --> 00:39:59,890 Mari kita memisahkan dengan aturan horisontal. 671 00:39:59,890 --> 00:40:04,065 Bagian id = "komentar". 672 00:40:04,065 --> 00:40:06,990 Apa yang akan kita lakukan di sini adalah, seperti sebelumnya, 673 00:40:06,990 --> 00:40:09,880 iterate melalui semua komentar. 674 00:40:09,880 --> 00:40:12,960 Jadi sebenarnya bagaimana kita melakukan ini adalah, seperti yang saya sebutkan, cukup ajaib. 675 00:40:12,960 --> 00:40:14,440 >> Kami melakukan posting komentar. 676 00:40:14,440 --> 00:40:17,410 677 00:40:17,410 --> 00:40:22,710 Dan kemudian kita dapat melakukan ini untuk masing-masing loop atas setiap komentar. 678 00:40:22,710 --> 00:40:25,740 Dan apa yang kita akan lakukan adalah div class komentar, 679 00:40:25,740 --> 00:40:29,240 dan kita akan benar-benar mencetak komentar ini. 680 00:40:29,240 --> 00:40:34,150 Jadi menampilkan bahwa hei, komentar name-- orang 681 00:40:34,150 --> 00:40:38,080 yang diposting comment-- ini mengatakan dot dot dot. 682 00:40:38,080 --> 00:40:41,240 Kita akan menempatkan ini dalam blok kutipan, hanya untuk membuatnya terlihat bagus. 683 00:40:41,240 --> 00:40:46,470 Dan kemudian komentar blok kutipan isi. 684 00:40:46,470 --> 00:40:49,790 685 00:40:49,790 --> 00:40:50,892 Dan foreach. 686 00:40:50,892 --> 00:40:53,100 Jadi sekarang ini akan lingkaran melalui semua komentar 687 00:40:53,100 --> 00:40:56,500 yang dikaitkan dengan masing-masing posting 688 00:40:56,500 --> 00:41:00,960 dan menampilkan masing-masing komentar. 689 00:41:00,960 --> 00:41:05,120 Aku akan menambahkan bagian lain di di sini, yang memungkinkan kita untuk menambahkan komentar. 690 00:41:05,120 --> 00:41:07,400 Kelas sehingga h3. 691 00:41:07,400 --> 00:41:09,580 Masukan judul di sini. 692 00:41:09,580 --> 00:41:10,934 Menambahkan komentar. 693 00:41:10,934 --> 00:41:13,886 694 00:41:13,886 --> 00:41:15,700 Dan kita akan menentukan bentuk baru. 695 00:41:15,700 --> 00:41:18,730 >> Jadi seperti sebelumnya, kami akan melakukan bentuk tindakan. 696 00:41:18,730 --> 00:41:22,740 Dan di sini, tindakan baru kami akan menentukan controller baru yang 697 00:41:22,740 --> 00:41:26,770 memungkinkan kita untuk menanggapi posting permintaan untuk membuat komentar. 698 00:41:26,770 --> 00:41:33,365 Jadi URL :: rute createComment. 699 00:41:33,365 --> 00:41:37,730 Aku akan lulus dalam parameter di sini. 700 00:41:37,730 --> 00:41:40,380 ID pos yang kita menciptakan komentar pada. 701 00:41:40,380 --> 00:41:45,340 702 00:41:45,340 --> 00:41:50,280 Dan kemudian metode ini Bentuk akan menjadi posting. 703 00:41:50,280 --> 00:41:57,240 >> Sekarang kita akan menambahkan dua bidang, kelompok bentuk. 704 00:41:57,240 --> 00:42:04,670 Ini akan menjadi masukan dengan nama "nama" dan class = "bentuk-control", 705 00:42:04,670 --> 00:42:14,250 ketik = "text", dan dengan placeholder = "Nama Anda." 706 00:42:14,250 --> 00:42:19,380 Kami juga akan mendefinisikan bidang bentuk lain, yang 707 00:42:19,380 --> 00:42:22,970 akan menjadi teks Daerah seperti yang kita miliki sebelumnya. 708 00:42:22,970 --> 00:42:25,480 Sama seperti sebelumnya, sebut saja konten. 709 00:42:25,480 --> 00:42:31,160 Class = "bentuk kontrol." 710 00:42:31,160 --> 00:42:41,660 Placeholder = "Tulis di sini." 711 00:42:41,660 --> 00:42:44,100 >> Dan hanya agar kita benar-benar dapat mengirimkannya, 712 00:42:44,100 --> 00:42:55,740 mengirimkan jenis dan class = "btn btn-primer." 713 00:42:55,740 --> 00:42:57,005 Menutup form. 714 00:42:57,005 --> 00:42:59,010 Tutup tindakan ini. 715 00:42:59,010 --> 00:43:06,580 Jadi sekarang jika kita me-refresh halaman ini di mana kita memiliki, katakanlah, sebuah pos tertentu. 716 00:43:06,580 --> 00:43:10,310 Kita harus reboot server. 717 00:43:10,310 --> 00:43:12,340 PHP tukang melayani. 718 00:43:12,340 --> 00:43:15,630 719 00:43:15,630 --> 00:43:18,334 Reboot ini. 720 00:43:18,334 --> 00:43:19,500 Kita harus mendefinisikan rute. 721 00:43:19,500 --> 00:43:25,090 Tapi untuk saat ini, mari kita mengambil ini keluar sehingga kita dapat benar-benar menunjukkan 722 00:43:25,090 --> 00:43:28,750 apa halaman tampak seperti, dan kemudian kita benar-benar akan membuat rute itu. 723 00:43:28,750 --> 00:43:29,250 Jadi, hey. 724 00:43:29,250 --> 00:43:37,080 Kami memiliki bentuk baru di sini sehingga kita dapat membuat komentar. 725 00:43:37,080 --> 00:43:39,950 Jadi mari kita benar-benar mendefinisikan fungsi dalam controller 726 00:43:39,950 --> 00:43:43,020 sehingga kita bisa menambahkan komentar. 727 00:43:43,020 --> 00:43:43,650 Mari kita kembali. 728 00:43:43,650 --> 00:43:48,420 Dan dalam blogcontroller.php, apa yang kita akan lakukan 729 00:43:48,420 --> 00:43:51,620 adalah membuat fungsi baru disebut membuat komentar. 730 00:43:51,620 --> 00:43:54,220 731 00:43:54,220 --> 00:43:57,040 >> Fungsi createComment publik. 732 00:43:57,040 --> 00:44:00,130 Ini akan memiliki satu parameter, ID posting 733 00:44:00,130 --> 00:44:02,280 bahwa kita mengomentari. 734 00:44:02,280 --> 00:44:04,790 Dan seperti sebelumnya, kami akan terlebih dahulu mendapatkan posting. 735 00:44:04,790 --> 00:44:10,790 Jadi posting, findOrfail id. 736 00:44:10,790 --> 00:44:15,020 Setelah itu, kita akan untuk membuat komentar baru. 737 00:44:15,020 --> 00:44:18,880 Jadi komentar = Komentar baru. 738 00:44:18,880 --> 00:44:26,820 Komentar name = Masukan :: mendapatkan nama. 739 00:44:26,820 --> 00:44:39,420 Konten komentar = baris baru yang sama dalam istirahat Input :: mendapatkan konten. 740 00:44:39,420 --> 00:44:43,460 >> Dan akhirnya, kita akan harus mengasosiasikan komentar ini dengan pos. 741 00:44:43,460 --> 00:44:47,230 Jadi kita akan menggunakan fungsi ini, komentar, 742 00:44:47,230 --> 00:44:50,260 yang memungkinkan kita untuk menyimpan hubungan ini. 743 00:44:50,260 --> 00:44:54,780 Jadi sekarang komentar ini akan memiliki otomatis pos ID. 744 00:44:54,780 --> 00:44:57,640 Kita juga bisa mengaturnya manual, tapi ini adalah 745 00:44:57,640 --> 00:45:02,490 lebih mudah dibaca sejauh sebagai fungsi berjalan. 746 00:45:02,490 --> 00:45:05,860 Dan setelah kami melakukan ini, apa yang ingin kita lakukan 747 00:45:05,860 --> 00:45:10,840 adalah mengarahkan pengguna ke rute yang ditentukan oleh viewPost 748 00:45:10,840 --> 00:45:16,010 dengan array dengan parameter pos ID. 749 00:45:16,010 --> 00:45:20,360 750 00:45:20,360 --> 00:45:24,660 >> Dan sekarang sehingga sebenarnya ini fungsi, kita perlu mendefinisikan rute ini. 751 00:45:24,660 --> 00:45:27,126 Rute :: pos. 752 00:45:27,126 --> 00:45:32,800 Dan sekarang kita akan menyebutnya posting memangkas ID slash komentar. 753 00:45:32,800 --> 00:45:36,725 Array menggunakan fungsi baru yang baru saja kita buat. 754 00:45:36,725 --> 00:45:37,350 BlogController. 755 00:45:37,350 --> 00:45:40,820 756 00:45:40,820 --> 00:45:44,770 CreateComment sebagai createComment. 757 00:45:44,770 --> 00:45:47,430 758 00:45:47,430 --> 00:45:50,120 Hebat Sekali. 759 00:45:50,120 --> 00:45:56,150 >> Jadi sekarang mudah-mudahan jika kita me-refresh halaman ini dan menambahkan komentar, katakanlah, David Malan. 760 00:45:56,150 --> 00:46:00,630 761 00:46:00,630 --> 00:46:03,920 "Mudah-mudahan ini bekerja." 762 00:46:03,920 --> 00:46:05,216 Kirim. 763 00:46:05,216 --> 00:46:09,050 Kami, pada kenyataannya, memiliki komentar di posting blog ini. 764 00:46:09,050 --> 00:46:13,760 765 00:46:13,760 --> 00:46:14,260 Keren. 766 00:46:14,260 --> 00:46:16,790 767 00:46:16,790 --> 00:46:21,430 Jadi sekarang kita memiliki cukup posting blog fungsional. 768 00:46:21,430 --> 00:46:23,180 Kami hanya akan menambahkan beberapa tweak jadi 769 00:46:23,180 --> 00:46:29,090 bahwa kita memiliki beberapa lebih berguna Informasi pada posting tersebut. 770 00:46:29,090 --> 00:46:32,780 >> Jadi, jika kita kembali ke halaman depan, kita tidak memiliki rasa 771 00:46:32,780 --> 00:46:38,790 berapa banyak komentar yang pada masing-masing posting ini. 772 00:46:38,790 --> 00:46:41,340 Jadi apa yang kita benar-benar akan lakukan adalah, di dalam model kami, 773 00:46:41,340 --> 00:46:51,250 mendefinisikan fungsi pembantu yang memungkinkan kita untuk menentukan jumlah komentar 774 00:46:51,250 --> 00:46:53,020 yang pergi dengan posting tertentu. 775 00:46:53,020 --> 00:46:56,050 Jadi kita akan membuat fungsi pembantu. 776 00:46:56,050 --> 00:46:58,020 >> Fungsi publik. 777 00:46:58,020 --> 00:46:58,770 GetNumCommentsStr. 778 00:46:58,770 --> 00:47:02,030 779 00:47:02,030 --> 00:47:07,180 Jadi string yang menentukan jumlah komentar yang pergi bersama dengan itu. 780 00:47:07,180 --> 00:47:12,850 Dan apa yang kita akan lakukan adalah mengatakan num itu = komentar ini menghitung. 781 00:47:12,850 --> 00:47:15,150 Jadi kita akan menghitung jumlah komentar. 782 00:47:15,150 --> 00:47:22,900 Dan jika nomor ini sama dengan 1, kami hanya akan kembali 1 komentar. 783 00:47:22,900 --> 00:47:28,890 Dan kemudian jika tidak, kami ingin kembali gabungan dari num dan komentar, 784 00:47:28,890 --> 00:47:31,890 sehingga kita mendapatkan pluralisasi yang benar. 785 00:47:31,890 --> 00:47:33,380 Hanya membuat satu kutipan. 786 00:47:33,380 --> 00:47:36,040 787 00:47:36,040 --> 00:47:37,640 Satu komentar. 788 00:47:37,640 --> 00:47:41,140 >> Dan sekarang kita dapat menggunakan fungsi ini langsung dalam pandangan kami. 789 00:47:41,140 --> 00:47:44,510 Jadi, jika kita kembali ke posting parsial yang kita buat, 790 00:47:44,510 --> 00:47:49,370 sekarang kita ingin benar-benar menampilkan jumlah komentar. 791 00:47:49,370 --> 00:47:52,660 Jadi apa yang bisa kita lakukan adalah posting, gunakan fungsi ini 792 00:47:52,660 --> 00:47:57,230 bahwa kita hanya diciptakan untuk menampilkan jumlah komentar. 793 00:47:57,230 --> 00:48:00,440 Jadi jika sekarang kita menyegarkan, itu tidak, pada kenyataannya, tampilan 794 00:48:00,440 --> 00:48:02,240 komentar nomor yang pergi bersama dengan itu. 795 00:48:02,240 --> 00:48:05,320 >> Jika kita ingin menjadi mewah jika Anda benar-benar melihat kode distribusi, 796 00:48:05,320 --> 00:48:07,800 kita benar-benar dapat menghubungkan ini untuk komentar. 797 00:48:07,800 --> 00:48:17,040 Jika Anda ingat, kita mendefinisikan dalam melihat bahwa ini bagian ID komentar. 798 00:48:17,040 --> 00:48:22,460 Jadi jika kita benar-benar ingin untuk menghubungkan langsung ke bagian komentar, apa 799 00:48:22,460 --> 00:48:36,000 kita akan lakukan di sini adalah href URL viewPost rute. 800 00:48:36,000 --> 00:48:40,550 Lulus dalam array ID pasca ID. 801 00:48:40,550 --> 00:48:46,140 Dan kemudian kita ingin pergi ke khususnya bagian komentar. 802 00:48:46,140 --> 00:48:49,900 >> Berikut mari kita menutup tag A. 803 00:48:49,900 --> 00:48:52,950 Jadi sekarang jika kita menyegarkan ini Halaman, kita klik ini. 804 00:48:52,950 --> 00:48:54,700 Kita akan pergi langsung ke bagian komentar. 805 00:48:54,700 --> 00:48:57,580 Jika kita memiliki posting lagi, Anda bisa benar-benar melihat bounce ini turun. 806 00:48:57,580 --> 00:49:02,668 Tapi Anda akan melihat bahwa itu tidak di bagian atas halaman. 807 00:49:02,668 --> 00:49:04,090 Keren. 808 00:49:04,090 --> 00:49:04,600 Hebat Sekali. 809 00:49:04,600 --> 00:49:08,582 Jadi itu cukup mudah contoh dari sesuatu yang sederhana 810 00:49:08,582 --> 00:49:09,790 yang dapat Anda lakukan dengan Laravel. 811 00:49:09,790 --> 00:49:13,230 >> Tapi Anda bisa melihat di sini bahwa kami telah melakukan banyak hal 812 00:49:13,230 --> 00:49:16,200 dengan jumlah yang cukup sedikit kode. 813 00:49:16,200 --> 00:49:19,420 Laravel memungkinkan kita untuk melakukan Query SQL di belakang layar. 814 00:49:19,420 --> 00:49:21,960 Itu tidak sanitasi bagi kita di belakang layar. 815 00:49:21,960 --> 00:49:25,940 Memungkinkan kita untuk melakukan hubungan ini sangat mudah tanpa kita perlu 816 00:49:25,940 --> 00:49:33,350 untuk melakukan SQL pernyataan untuk bergabung menggabungkan komentar dengan apa tulisan. 817 00:49:33,350 --> 00:49:36,480 Memungkinkan kita untuk melakukan hal ini warisan template 818 00:49:36,480 --> 00:49:43,780 sehingga kita dapat menentukan bersarang ini file sehingga kita tidak mengulangi diri kita sendiri, 819 00:49:43,780 --> 00:49:47,020 seperti ketika kita punya yang Tampilan posting blog 820 00:49:47,020 --> 00:49:50,770 bahwa kita tidak perlu copy dan paste kode. 821 00:49:50,770 --> 00:49:55,450 >> Dan dari sini Anda dapat membangun aplikasi semakin rumit. 822 00:49:55,450 --> 00:49:58,370 Anda bisa bayangkan jika kita ingin menerapkan log-in, 823 00:49:58,370 --> 00:50:05,532 kita bisa mengatakan, membawa pihak ketiga kerangka kerja yang memungkinkan kita untuk melakukan itu. 824 00:50:05,532 --> 00:50:07,490 Ada banyak dari mereka yang benar-benar, benar-benar 825 00:50:07,490 --> 00:50:09,970 besar yang bisa melakukan seperti, pemulihan password. 826 00:50:09,970 --> 00:50:14,450 Dan itu akan mengirimkan ulang email password. 827 00:50:14,450 --> 00:50:18,260 Kita bisa menerapkan izin sehingga saya bisa membuat sebuah tulisan, 828 00:50:18,260 --> 00:50:20,350 tapi orang lain tidak dapat mengeditnya. 829 00:50:20,350 --> 00:50:24,610 Kita bisa menerapkan fungsi untuk menghapus posting. 830 00:50:24,610 --> 00:50:28,160 >> Tapi Anda bisa lihat di sini bahwa kita memiliki cukup banyak semua komponen dasar 831 00:50:28,160 --> 00:50:31,640 untuk membangun beberapa benar-benar, benar-benar, aplikasi web dinamis dan menarik. 832 00:50:31,640 --> 00:50:34,035 Maka dengan itu, saya pikir kita baik. 833 00:50:34,035 --> 00:50:35,720 Apakah kalian memiliki pertanyaan? 834 00:50:35,720 --> 00:50:36,220 Iya Nih? 835 00:50:36,220 --> 00:50:38,090 >> SPEAKER 3: Bagaimana Anda mendapatkan konten statis? 836 00:50:38,090 --> 00:50:39,256 >> ERIC Ouyang: konten statis. 837 00:50:39,256 --> 00:50:45,520 Jadi Anda melihat sebelumnya bahwa ketika kita memiliki hak ini di sini, isi tata letak ini, 838 00:50:45,520 --> 00:50:49,625 Tampilan make, kami punya ini tanpa array ini kemudian. 839 00:50:49,625 --> 00:50:56,440 840 00:50:56,440 --> 00:50:59,152 Blog.index, kami punya ini hanya sebagai file statis. 841 00:50:59,152 --> 00:51:00,860 Jadi jika kita tidak lulus apapun bersama untuk itu, 842 00:51:00,860 --> 00:51:03,340 itu hanya akan membuat HTML langsung. 843 00:51:03,340 --> 00:51:09,240 Tetapi jika kita lulus dalam asosiatif ini array posting, yang dinamis 844 00:51:09,240 --> 00:51:12,950 ditarik dari database, kita dapat membuat halaman dinamis. 845 00:51:12,950 --> 00:51:13,450 Keren. 846 00:51:13,450 --> 00:51:14,830 Ada pertanyaan lain? 847 00:51:14,830 --> 00:51:16,786 848 00:51:16,786 --> 00:51:19,720 SPEAKER 3: Bagaimana Anda membandingkan Laravel untuk mungkin beberapa pilihan lain? 849 00:51:19,720 --> 00:51:20,525 ERIC Ouyang: Tentu. 850 00:51:20,525 --> 00:51:21,025 Ya. 851 00:51:21,025 --> 00:51:23,430 Jadi Laravel is-- itu a question-- besar 852 00:51:23,430 --> 00:51:26,190 salah satu dari banyak pilihan untuk kerangka web. 853 00:51:26,190 --> 00:51:31,160 Jadi Ruby on Rails adalah salah satu yang populer. 854 00:51:31,160 --> 00:51:34,590 Saya percaya Twitter dulu diimplementasikan dengan Ruby on Rails. 855 00:51:34,590 --> 00:51:37,600 Saya pikir mereka sudah sejak beralih. 856 00:51:37,600 --> 00:51:40,780 Ada satu lagi yang disebut FuelPHP. 857 00:51:40,780 --> 00:51:46,120 >> Jadi Ruby on Rails menggunakan bahasa Ruby dan menerapkan banyak hal MVC 858 00:51:46,120 --> 00:51:48,200 yang kita lihat di sini. 859 00:51:48,200 --> 00:51:52,320 FuelPHP adalah framework PHP lain. 860 00:51:52,320 --> 00:51:54,490 Django adalah salah satu favorit saya. 861 00:51:54,490 --> 00:51:57,010 Ini adalah kerangka web untuk Python. 862 00:51:57,010 --> 00:52:01,270 Jadi, Anda dapat menulis aplikasi web Anda di Python. 863 00:52:01,270 --> 00:52:03,760 Jadi ada satu ton pilihan ini. 864 00:52:03,760 --> 00:52:06,170 >> Laravel, saya pikir, oleh dan besar benar favorit saya 865 00:52:06,170 --> 00:52:08,232 sekarang ke PHP hanya karena komponen 866 00:52:08,232 --> 00:52:09,440 yang kita bicarakan sebelumnya. 867 00:52:09,440 --> 00:52:11,910 Itu Komposer diaktifkan. 868 00:52:11,910 --> 00:52:15,750 Ini termasuk benar-benar, benar-benar Sistem ORM ekspresif. 869 00:52:15,750 --> 00:52:18,800 Juga memiliki template benar-benar mengagumkan bahasa yang beberapa yang lain 870 00:52:18,800 --> 00:52:20,630 hanya tidak memberikan. 871 00:52:20,630 --> 00:52:21,400 Dan migrasi. 872 00:52:21,400 --> 00:52:23,432 Migrasi mengagumkan juga. 873 00:52:23,432 --> 00:52:24,860 Keren? 874 00:52:24,860 --> 00:52:25,390 Mengagumkan. 875 00:52:25,390 --> 00:52:27,560 Nah, terima kasih banyak untuk menonton seminar ini, 876 00:52:27,560 --> 00:52:30,650 dan semoga sukses pada proyek akhir Anda. 877 00:52:30,650 --> 00:52:31,616