Magento 2: Bagaimana cara mengirim data menggunakan formulir Ajax dalam formulir khusus?
11
Adakah yang bisa menjelaskan bagaimana cara membuat formulir sederhana di halaman Magento-2 untuk mengirim data menggunakan Ajax? Saya sudah memiliki aksi form dan controller, yang mengirim data tanpa menggunakan ajax.
Anda bisa mendapatkan data dalam pengontrol menggunakan $ this-> getRequest () -> getParam ('customdata1');
Rakesh Jesadiya
1
respons diterima dalam respons skrip.
Rakesh Jesadiya
2
complete: function (response) di sini Anda sudah mendapat respons.
Rakesh Jesadiya
1
Anda harus mengatur respons di atas $ this -> _ jsonHelper-> jsonEncode (['default_country' => $ country, 'state' => $ state,]) kode di controller
Rakesh Jesadiya
1
dalam kasus di atas default_country dan status dikembalikan dari respons
Rakesh Jesadiya
12
Jawaban yang diterima itu baik, tetapi saya pikir bisa bermanfaat memanfaatkan validasi js yang ditawarkan magento core. Jadi, coba gunakan skrip js di bawah ini:
<scripttype="text/javascript">
require(["jquery","mage/mage"],function($){
$(document).ready(function(){
$('#form_id').mage('validation',{
submitHandler:function(form){
$.ajax({
url:"url to module/controller/action",
data: $('#form_id').serialize(),
type:'POST',
dataType:'json',
beforeSend:function(){// show some loading icon},
success:function(data, status, xhr){// data contains your controller response},
error:function(xhr, status, errorThrown){
console.log('Error happens. Try again.');
console.log(errorThrown);}});}});});});</script>
Jangan lupa bahwa controller harus mengembalikan respons JSON seperti:
Jawaban:
Anda bisa mengatur kode di bawah ini dalam file phtml Anda untuk menggunakan ajax, Anda harus mengubah customurl Anda di dalam kode di bawah ini,
di dalam file controller Anda jalankan metode () ,
sumber
Jawaban yang diterima itu baik, tetapi saya pikir bisa bermanfaat memanfaatkan validasi js yang ditawarkan magento core. Jadi, coba gunakan skrip js di bawah ini:
Jangan lupa bahwa controller harus mengembalikan respons JSON seperti:
sumber