By default Image data are not post using ajax. only plain data will be passed as Ajax post. if we need to pass image data using ajax we need to call ajax as below way,
Call jquery using requirejs way in backend template file,
Let’s create a simple example of the form,
<form id="abcd" action="" enctype="multipart/form-data"> <div class="control"> <input type='file' class='multi' name='attachment' id='attachment'/> </div> <button type="button" name="submitajax" id="submitajax"></button> </form> <script> require(["jquery"],function($) { $("#submitajax").on('click', function() { var file = document.getElementById('attachment').files[0]; var form; if (typeof file != 'undefined') { form = new FormData(document.getElementById('attachment')); form.append('form_key',window.FORM_KEY); form.append('attachment', file); form.append('id', getId); } $.ajax({ url: "<?= $block->getUrl('myajax/custom/urlname'); ?>", type: 'post', mimeTypes: 'multipart/form-data', data: form, cache: false, contentType: false, //this is must required processData: false, //this is must required beforeSend: function() { $('body').trigger('processStart'); }, success: function (response) { console.log(response); $('body').trigger('processStop'); } }); }); }); </script>
We need to Use You FormData() object of Javascript to store our image data and using above way we can just send image data to server side using ajax.