Rumah >hujung hadapan web >Soal Jawab bahagian hadapan >Bagaimana untuk menghantar nilai dalam laluan rangka kerja vuejs
Kaedah pemindahan nilai penghalaan rangka kerja Vuejs: 1. Panggil terus pernyataan "$router.push(...)" untuk membawa parameter bagi pemindahan nilai lompatan 2. Gunakan axios untuk memindahkan nilai, anda boleh memanggil "; pernyataan .$axios.get(...)" ini untuk lulus nilai.
Persekitaran pengendalian tutorial ini: sistem Windows 7, vue versi 2.9.6, komputer DELL G3.
Ringkaskan pemindahan nilai penghalaan dalam Vue, yang melibatkan penggunaan aksios
Mudah untuk mengelirukan kaedah ini apabila menggunakannya
dan konfigurasi penghalaan yang sepadan:
{ path: '/detail/:id', name: 'Detail', component: Detail }
Nota: Pastikan anda menambah /:id
selepas laluan, id hanyalah parameter Nama tidak mengapa, tetapi ia perlu konsisten dengan nama parameter semasa menghantar dan menerima
Panggil terus $router.push
untuk melaksanakan lompatan dengan parameter
this.$router.push({ path:`/detail/${id}` })
Nota: dalam Apabila melompat untuk memindahkan parameter, path
diikuti oleh dua tanda belakang dan bukannya petikan berganda atau petikan tunggal, dan parameter yang diperlukan diluluskan dalam bentuk ${}
Terima dalam anak komponen
this.$route.params.id
Nota: Ia adalah route
, bukan router
jika menggunakan atribut penghalaan name
Untuk menentukan laluan padanan untuk melepasi parameter, anda perlu melakukan ini:
Konfigurasi laluan yang sepadan:
{ path: '/detail', name: 'Detail', component: Detail }
Lompat dengan parameter:
this.$router.push({ name: 'Detail', params: { id: id } })
Nota: Anda tidak boleh gunakan /:id
untuk menghantar parameter di sini, kerana komponen induk telah menggunakan params
untuk membawa parameter. Terima parameter dalam
subkomponen:
this.$route.params.id
Sekali lagi, ia adalah route
, bukan router
Gunakan
params
untuk lulus parameter, dan gunakan atributname
untuk sepadan dengan laluan lompatan Sama seperti penyerahanpost
, parameter tidak akan muncul dalam laluan lompat.
Apabila kita perlu membawa data bahagian hadapan ke antara muka bahagian belakang
Kita juga boleh menghantar nilai dalam dengan cara ini
Contohnya:
Kod untuk memanggil antara muka hujung belakang di hujung hadapan:
this.$axios.get(`http://127.0.0.1:3000/api/user/find/${id}`)
Terima di hujung belakang:
router.get('/find/:id',(req,res)=>{ //接收let id = req.params.id })
Ambil perhatian bahawa ia adalah permintaan dapatkan
Kaedah permintaan ini akan dipaparkan dalam bar alamat
Contoh pautan bar alamat: http://127.0. 0.1:3000/api/user/ find/10
Konfigurasi penghalaan yang sepadan:
{ path: '/detail', name: 'Detail', component: Detail }
Lompat dengan parameter:
this.$router.push({ path:'/detail', query:{ id:id } })
Nota: Apa yang digunakan di sini ialah query
dan kemudian diterima dalam sub-komponen:
this.$route.query.id
Nota: Nama parameter mesti konsisten semasa menerima, jangan gunakan params
untuk menerima query
untuk menghantar parameter Gunakan sepadan dengan laluan lompat, serupa dengan penyerahan dan parameter dipaparkan dalam laluan.
Bahagian hadapan memanggil kod Antara muka hujung belakang:nilai lulus aksios
query
path
Jika anda mahu menggunakannya dalam aksios, anda boleh melakukan ini:get
Contohnya:
Malah, ini sama seperti menulis satu lagi
di atas, tetapi ia lebih mudahNota: Ia dibalut dengan dua tanda belakang , diikuti dengan tanda ? dan bukannya /
this.$axios.get(`http://127.0.0.1:3000/api/user/delete?name=${name}&age=${age}`)
query
Menggunakan kaedah ini, anda boleh menghantar berbilang nilai dalam bar alamat sekaligus, dan menggunakan ampersand untuk menyambungkannya, iaitu
Oleh kerana bar alamat penyemak imbas mempunyai had panjang, tidak disyorkan untuk menggunakan kaedah ini jika terdapat terlalu banyak parameter
get
di bahagian belakang Untuk menerima:
untuk menerimaNota: Jangan tambah apa-apa selepas
di sini apabila menerima, gunakan
router.get('/delete'(req,res)=>{ let name = req.query.name; let age = req.query.age; })
Menggunakan kaedah ini untuk menghantar nilai juga akan dipaparkan dalam bar alamatContoh pautan bar alamat: http://127.0.0.1:3000/api/user/delete?name =zhangsan&age=10/delete
query
Peringatan khas
Jika anda menggunakan
untuk sepadan dengan laluan lompatan
untuk lulus parameter, anda mesti menggunakan atribut
params
name
Kaedah tiga query
path
nilai lulus axiosdan diterima di bahagian belakang:
Nota: Apabila menerima di sini, gunakan
untuk menerima, iaitumeminta
this.$axios.get(`http://127.0.0.1:3000/api/user/add`,{name=this.name,age=this.age`})
Secara amnya apabila kami ingin menghantar data ke pelayan, kami menggunakan permintaan post
Kaedah permintaan ini selamat Jika anda menggunakan kaedah ini, data tidak akan dipaparkan dalam bar alamat.
Cadangan berkaitan: "tutorial vue.js"
Atas ialah kandungan terperinci Bagaimana untuk menghantar nilai dalam laluan rangka kerja vuejs. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!