Rumah  >  Artikel  >  hujung hadapan web  >  javascript buang tanda soal

javascript buang tanda soal

WBOY
WBOYasal
2023-05-06 11:57:071066semak imbas

Kata Pengantar
Apabila kami menggunakan JavaScript untuk interaksi data, kami sering menghadapi masalah - URL mengandungi tanda soal (?), yang mungkin menyebabkan ralat dalam program kami, jadi ia perlu ditangani. Artikel ini akan memperkenalkan beberapa kaedah untuk mengalih keluar tanda soal dalam URL dan membantu pembaca menyelesaikan masalah yang serupa.

1. Penerangan masalah
Biasanya apabila kami menghantar permintaan GET ke pelayan, URL akan mengandungi tanda soal (?). Contohnya: http://example.com?id=1&name=Zhang San. URL ini mengandungi tanda soal yang memisahkan URL dan rentetan pertanyaan.

Walau bagaimanapun, dalam beberapa kes, kami ingin mengalih keluar tanda soal, dan kemudian pemprosesan diperlukan. Contohnya, apabila melompat ke halaman, anda mungkin perlu mengalih keluar tanda soal dalam URL untuk memastikan lompatan halaman yang betul.

2. Penyelesaian
1 Gunakan kaedah subrentetan() untuk membuang tanda soal

Ia adalah kaedah biasa. Menggunakan subrentetan fungsi rentetan JavaScript(), anda boleh memintas subrentetan URL dan mengalih keluar tanda soal. Contohnya adalah seperti berikut:

let url = "http://example.com?id=1&name=张三";
let newUrl = url.substring(0, url.indexOf("?"));
console.log(newUrl);

Output kod ini ialah: "http://example.com".

Dalam kod di atas, kami mula-mula mengisytiharkan URL, dan kemudian menggunakan fungsi subrentetan() untuk mengalih keluar tanda soal. Fungsi substring() menerima dua parameter Parameter pertama ialah kedudukan permulaan rentetan yang akan dipintas, dan parameter kedua ialah kedudukan akhir rentetan yang akan dipintas (tidak termasuk aksara pada kedudukan akhir).

Dalam kod di atas, kami menggunakan fungsi indexOf() untuk mencari kejadian pertama tanda soal. Fungsi ini mengembalikan kedudukan subrentetan, atau -1 jika tidak ditemui. Menggunakan fungsi subrentetan(), kita mendapatkan aksara sebelum "?", iaitu alamat URL sebelum tanda soal.

2. Gunakan kaedah replace() untuk mengalih keluar tanda soal

Fungsi replace() ialah kaedah biasa yang lain. Ia menggantikan subrentetan dalam rentetan dengan rentetan lain. Contohnya adalah seperti berikut:

let url = "http://example.com?id=1&name=张三";
let newUrl = url.replace("?", "");
console.log(newUrl);

Hasil output kod ini ialah: "http://example.comid=1&name=Zhang San".

Dalam kod di atas, kami menggunakan fungsi replace() untuk menggantikan tanda soal (?) dengan rentetan kosong (""). Hasil daripada kaedah ini ialah rentetan URL dengan tanda soal dialih keluar.

Walau bagaimanapun, kaedah ini akan menggantikan semua tanda soal dalam URL dengan rentetan kosong, jadi ia boleh menyebabkan ralat. Jadi kaedah ini hanya berfungsi apabila terdapat hanya satu tanda soal dalam URL.

3 Gunakan kaedah split() untuk mengalih keluar tanda soal

Fungsi split() boleh memisahkan rentetan kepada tatasusunan rentetan dan mengembalikan tatasusunan. Apabila memproses URL, kita boleh menggunakan fungsi split() untuk memisahkan tanda soal dan mengambil elemen pertama. Contohnya adalah seperti berikut:

let url = "http://example.com?id=1&name=张三";
let newUrl = url.split("?")[0];
console.log(newUrl);

Output kod ini ialah: "http://example.com".

Dalam kod di atas, kami menggunakan kaedah split() untuk memisahkan rentetan kepada dua bahagian: URL dan rentetan pertanyaan. Kemudian kami mengeluarkan bahagian pertama, iaitu alamat URL dengan tanda soal dialih keluar.

Ringkasan
Di atas ialah beberapa cara untuk mengalih keluar tanda soal dalam URL menggunakan JavaScript. Apabila kami menghadapi masalah semasa menghantar permintaan GET, adalah penting untuk membuat pengubahsuaian untuk memastikan operasi normal program. Melalui pengenalan artikel ini, saya percaya pembaca telah belajar cara cepat menangani masalah ini.

Atas ialah kandungan terperinci javascript buang tanda soal. 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