在通过 AJAX 将数据发送到资源之前验证表单。 Liferay 7.3.5

Validate the form before sending the data via AJAX to resources. Liferay 7.3.5

我正在 Liferay 7.3.5 中开发一个表单。该表单的目的是在将数据 AJAX 发送到资源之前验证数据。

代码工作正常,我遇到的问题是我找不到在 AJAX 发送数据之前验证表单字段的解决方案。 AJAX代码段如下

//Evento boton de formulario
        $('#<portlet:namespace/>button-contactForm').click(function(){
                
            var form = $('#<portlet:namespace/>fm')[0];
            var data = new FormData(form);
        
            $.ajax({
                type: "POST",
                //enctype: 'multipart/form-data',
                url: '${emailResourceURL}',
                data: data,
                processData: false,
                contentType: false,
                cache: false,
                timeout: 600000
                  
            }).done(function( data, textStatus, jqXHR ) {
                $('#<portlet:namespace/>fm').trigger('reset');
                console.log("La solicitud se ha completado correctamente." );
                
            }).fail(function( jqXHR, textStatus, errorThrown ) {
                console.log("La solicitud ha fallado: " +  textStatus);
                
            });
            
        }); 

在这种情况下如何验证表单字段?我在下面向您展示了完整的代码。

<%@ include file="/init.jsp" %>

<portlet:resourceURL id="email" var="emailResourceURL"/>
<portlet:resourceURL id="captcha" var="captchaResourceURL"/>

<div id="contactForm">
    <div class="content-width-section">
        <aui:form name="fm" method="post" enctype="multipart/form-data">
            <aui:fieldset-group markupView="lexicon">
            
                <aui:fieldset label="form.field.title">
                    <aui:input id="subject-contactForm" placeholder="form.field.subject" label="" name="${subject}" type="text">
                        <aui:validator name="required"></aui:validator>
                    </aui:input>
                    
                    <aui:row>
                        <aui:col width="50">
                            <aui:input id="name-contactForm" placeholder="form.field.name" label="" name="${name}" type="text">
                                <aui:validator name="required"></aui:validator>
                            </aui:input>
                        </aui:col>
                        
                        <aui:col width="50">
                            <aui:input id="surname-contactForm" placeholder="form.field.surname" label="" name="${surname}" type="text">
                                <aui:validator name="required"></aui:validator>
                            </aui:input>
                        </aui:col>
                    </aui:row>
                    
                    <aui:row>
                        <aui:col width="50">
                            <aui:input id="email-contactForm" placeholder="form.field.email" label="" name="${email}" type="text">
                                <aui:validator name="required"></aui:validator>
                                <aui:validator name="email"></aui:validator>
                            </aui:input>
                        </aui:col>
                        
                        <aui:col width="50">
                            <aui:input id="phone-contactForm" placeholder="form.field.phone" label="" name="${phone}" type="text">
                                <aui:validator name="digits"></aui:validator>
                            </aui:input>
                        </aui:col>
                    </aui:row>
                    
                    <aui:input id="message-contactForm" placeholder="form.field.message" label="" name="${message}" type="textarea">
                        <aui:validator name="required"></aui:validator>
                    </aui:input>

                    <div class="input-group">
                        <div class="input-file-upload col-xs-12 col-sm-8 col-md-9 col-lg-10">
                            <aui:input id="fileName-contactForm" placeholder="form.field.attached.document" label="" name="${fileName}" type="text" />
                        </div>
                        <div class="btn-file-upload col-xs-12 col-sm-4 col-md-3 col-lg-2">
                            <aui:input id="attachedDocument-contactForm" label="form.button.attached.document" name="${attachedDocument}" type="file" >
                                <aui:validator name="acceptFiles">'doc,docx,pdf'</aui:validator>
                            </aui:input>
                        </div>
                    </div>
                    
                    <aui:input name="form.field.privacy.policy" type="radio">
                        <aui:validator name="required"></aui:validator>
                    </aui:input>
                    
                    <liferay-captcha:captcha url="${captchaResourceURL}" />     
                </aui:fieldset>
                
            </aui:fieldset-group>
            
            <aui:button-row>
                <aui:button id="button-contactForm" name="button" type="button" value="form.button.send" />
            </aui:button-row>
        </aui:form>
    </div>
</div>

<script>

    //Bordes y titulo del formulario
    $('#contactForm .main-content-card').removeClass('card-horizontal');
    $('#contactForm #Title').addClass('h2 title-section text-center my-4');
    
    //Boton seleccion de documento adjunto
//  $('#contactForm .input-group .input-file-upload input').attr('disabled', '');   
    $('#contactForm .input-group .btn-file-upload label').addClass('buttonBlue mayusculas p-2 d-flex justify-content-center');
    
    //Radio button 'politica de privacidad'
    $('#contactForm .radio').addClass('textGraySade');
    $('#contactForm .radio.textGraySade label').addClass('d-flex align-items-center');
    
    //Boton de envio de formulario
    $('#contactForm button').removeClass('btn-primary btn-secondary').addClass('buttonBlue mayusculas');
    $('#contactForm .button-holder').addClass('d-flex justify-content-center');
    
    $(document).ready(function(){
        
        //Evento boton seleccion de documento adjunto
        $('#contactForm .btn-file-upload input:file').change(function(){
            var pathFile = $(this).val();
            var indexToken = pathFile.lastIndexOf('\') + 1;
            var fileName = pathFile.substring(indexToken, pathFile.length);
            
            $('#contactForm .input-file-upload input:text').val("");
            $('#contactForm .input-file-upload input:text').val(fileName);
        });
        
        //Evento campo de texto de documento adjunto
        $('#contactForm .input-file-upload input:text').click(function(){
            $(this).val('');
            $('#contactForm .btn-file-upload input:file').val('');
        });
        
        //Evento boton de formulario
        $('#<portlet:namespace/>button-contactForm').click(function(){
                
            var form = $('#<portlet:namespace/>fm')[0];
            var data = new FormData(form);
        
            $.ajax({
                type: "POST",
                enctype: 'multipart/form-data',
                url: '${emailResourceURL}',
                data: data,
                processData: false,
                contentType: false,
                cache: false,
                timeout: 600000
                  
            }).done(function( data, textStatus, jqXHR ) {
                $('#<portlet:namespace/>fm').trigger('reset');
                console.log("La solicitud se ha completado correctamente.");
                
            }).fail(function( jqXHR, textStatus, errorThrown ) {
                console.log("La solicitud ha fallado: " +  textStatus);
                
            });
            
        }); 
        
    });

</script>

谢谢!

此致!

您可以在 ajax 调用之前使用 js 验证表单。将您的 ajax 代码片段修改为此

        //Evento boton de formulario
        $('#<portlet:namespace/>button-contactForm').click(function(){
            
            // get your form validator
            var formValidator = Liferay.Form.get('<portlet:namespace />fm').formValidator;

            // manually validates the form
            formValidator.validate();
            
            // verify if there are errors. If so, returns nothing
            if (formValidator.hasErrors()) return;
            
            var form = $('#<portlet:namespace/>fm')[0];
            var data = new FormData(form);
        
            $.ajax({
                type: "POST",
                enctype: 'multipart/form-data',
                url: '${emailResourceURL}',
                data: data,
                processData: false,
                contentType: false,
                cache: false,
                timeout: 600000
                  
            }).done(function( data, textStatus, jqXHR ) {
                $('#<portlet:namespace/>fm').trigger('reset');
                console.log("La solicitud se ha completado correctamente.");
                
            }).fail(function( jqXHR, textStatus, errorThrown ) {
                console.log("La solicitud ha fallado: " +  textStatus);
                
            });
            
        });