Мои сообщения об ошибках проверки не отображаются (Javascript) - PullRequest
0 голосов
/ 23 апреля 2020

У меня есть форма, которая получает информацию о погоде на местах на основе пользовательского ввода. Я пытаюсь установить пользовательские сообщения проверки для моих полей ввода, но они не будут отображаться.

У меня сложилось впечатление, что отправка формы все равно заставит их отображаться, если я не включу в меню 1010 * предотвращение ошибок, но, возможно, это не так.

Есть ли альтернативный способ отображения сообщений об ошибках таким образом? Я стараюсь по возможности избегать использования предупреждений.

Я все еще разрабатываю концепции, поэтому извиняюсь за небрежное форматирование.

 $(document).ready(function () {
        var inputType = 1;

        $("#Radio1").click(function() {
            $("#lbl1").text("City Name:");
            $("#lbl2").text("Country Code:");
            $("#Firstbox").removeAttr("min max step");
            $("#Secondbox").removeAttr("min max step");

            $("#Firstbox").attr({
                "type" : "text",
                "pattern" : "[a-zA-Z]{2,}",
                "value" : "Regina",
                "setCustomValidity" : "Must be 2 or more characters in length"
            });

            $("#Secondbox").attr({
                "type" : "text",
                "pattern" : "[a-zA-Z]{2}",
                "value" : "ca",
                "setCustomValidity" : "Must be 2 characters in length"
            });

            inputType = 1;
        });

        $("#Radio2").click(function() {
            $("#lbl1").text("Postal Code:");
            $("#lbl2").text("Country Code:");
            $("#Firstbox").removeAttr("min max step");
            $("#Secondbox").removeAttr("min max step");

            $("#Firstbox").attr({
                "type" : "text",
                "pattern" : "[A-Z][0-9][A-Z]",
                "value" : "S4X",
                "setCustomValidity" : "Must follow format: S4X"
            });

            $("#Secondbox").attr({
                "type" : "text",
                "pattern" : "[a-zA-Z]{2}",
                "value" : "ca",
                "setCustomValidity" : "Must be 2 characters in length"
            });

            inputType = 2;
        });

        $("#Radio3").click(function() {
            $("#lbl1").text("Latitude:");
            $("#lbl2").text("Longitude:");
            $("#Firstbox").removeAttr("pattern");
            $("#Secondbox").removeAttr("pattern");
            $("#Firstbox").attr({
                "type" : "number",
                "min" : "-90",
                "max" : "90",
                "step" : "any",
                "value" : "50.4",
                "setCustomValidity" : "Must be betwen -90 and 90"
            });

            $("#Secondbox").attr({
                "type" : "number",
                "min" : "-180",
                "max" : "180",
                "step" : "any",
                "value" : "-105.5",
                "setCustomValidity" : "Must be betwen -180 and 180"
            });

            inputType = 3;
        });

        $("#SearchButton").click(function () {
            if (checkValidity()) {
                var xhttp = new XMLHttpRequest();
                xhttp.onreadystatechange = function () {
                    if (this.readyState == 4 && this.status == 200) { 
                        var SearchResponse = this.responseText;
                        document.getElementById("ResponseText").innerHTML = SearchResponse;

                        var obj = JSON.parse(SearchResponse);
                        var city_name = obj["name"];
                        var country_name = obj["sys"]["country"]; 
                        var weather_description = obj["weather"][0]["description"]; 
                        var temp = obj["main"]["temp"]; 
                        var pressure = obj["main"]["pressure"];
                        var wind_speed = obj["wind"]["speed"];

                        var SearchResultsHTML = "City: " + city_name + "<br />" +
                                                "Country: " + country_name + "<br />" +
                                                "Weather: " + weather_description + "<br />" +
                                                "Temperature: " + temp + "<br />" +
                                                "Pressure: " + pressure + "<br />" +
                                                "Wind Speed: " + wind_speed + "<br />";

                        $("#SearchResults").html(SearchResultsHTML);
                    }
                }



                var Firstbox = $("#Firstbox").val();
                var Secondbox = $("#Secondbox").val();

                var apiKey = "52453f34dee0d65b1a41a02656142c6b";

                if (inputType==1) {
                    var SearchString = "http://api.openweathermap.org/data/2.5/weather" + 
                                       "?q=" + Firstbox + "," + Secondbox + 
                                       "&APPID=" + apiKey;
                } else if (inputType==2) {
                    var SearchString = "http://api.openweathermap.org/data/2.5/weather" + 
                                       "?zip=" + Firstbox + "," + Secondbox + 
                                       "&APPID=" + apiKey;
                } else if (inputType==3) {
                    var SearchString = "http://api.openweathermap.org/data/2.5/weather" + 
                                       "?lat=" + Firstbox + "&lon=" + Secondbox + 
                                       "&APPID=" + apiKey;
                }

                xhttp.open("GET", SearchString, true);
                xhttp.send();
            }
        });

        function checkValidity() {
            var first = document.getElementById('Firstbox');
            var second = document.getElementById('Secondbox');

            if (first.validity.valid && second.validity.valid) {
                return true;
            } else {
                return false;
            }
        }
    });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<form id="searchForm" method="POST" action="URL">
  <h2>OpenWeatherMap Weather Search</h2>
  Search by:<br/>
  <input id="Radio1" name="searchBy" type="radio" checked /> City Name<br/>
  <input id="Radio2" name="searchBy" type="radio"> Postal Code<br/>
  <input id="Radio3" name="searchBy" type="radio" /> Latitude / Longitude<br/>
  <br/>
  <label id="lbl1">City Name:</label><input id="Firstbox" class="validated" type="text" required pattern=".{2,}" value="Regina" />
  <label id="lbl2">Country Code:</label><input id="Secondbox" class="validated" type="text" required pattern="[a-zA-Z]{2}" value="ca" /> <br/>
  <input id="SearchButton" type="button" value="Search" />
</form>

<h2>Search Results:</h2>
<h3>Raw Result Text</h3>
<p id="ResponseText"></p>
<h3>Parsed Results</h3>
<p id="SearchResults"></p>

1 Ответ

0 голосов
/ 23 апреля 2020

вы можете изменить свой чек-валидацию следующим образом

$(document).ready(function () {
        var inputType = 1;

        $("#Radio1").click(function() {
            $("#lbl1").text("City Name:");
            $("#lbl2").text("Country Code:");
            $("#Firstbox").removeAttr("min max step");
            $("#Secondbox").removeAttr("min max step");

            $("#Firstbox").attr({
                "type" : "text",
                "pattern" : "[a-zA-Z]{2,}",
                "value" : "Regina",
                "setCustomValidity" : "Must be 2 or more characters in length"
            });

            $("#Secondbox").attr({
                "type" : "text",
                "pattern" : "[a-zA-Z]{2}",
                "value" : "ca",
                "setCustomValidity" : "Must be 2 characters in length"
            });

            inputType = 1;
        });

        $("#Radio2").click(function() {
            $("#lbl1").text("Postal Code:");
            $("#lbl2").text("Country Code:");
            $("#Firstbox").removeAttr("min max step");
            $("#Secondbox").removeAttr("min max step");

            $("#Firstbox").attr({
                "type" : "text",
                "pattern" : "[A-Z][0-9][A-Z]",
                "value" : "S4X",
                "setCustomValidity" : "Must follow format: S4X"
            });

            $("#Secondbox").attr({
                "type" : "text",
                "pattern" : "[a-zA-Z]{2}",
                "value" : "ca",
                "setCustomValidity" : "Must be 2 characters in length"
            });

            inputType = 2;
        });

        $("#Radio3").click(function() {
            $("#lbl1").text("Latitude:");
            $("#lbl2").text("Longitude:");
            $("#Firstbox").removeAttr("pattern");
            $("#Secondbox").removeAttr("pattern");
            $("#Firstbox").attr({
                "type" : "number",
                "min" : "-90",
                "max" : "90",
                "step" : "any",
                "value" : "50.4",
                "setCustomValidity" : "Must be betwen -90 and 90"
            });

            $("#Secondbox").attr({
                "type" : "number",
                "min" : "-180",
                "max" : "180",
                "step" : "any",
                "value" : "-105.5",
                "setCustomValidity" : "Must be betwen -180 and 180"
            });

            inputType = 3;
        });

        $("#SearchButton").click(function () {
            var Validation = checkValidity();
            if ((Validation==true)) {
                var xhttp = new XMLHttpRequest();
                xhttp.onreadystatechange = function () {
                    if (this.readyState == 4 && this.status == 200) { 
                        var SearchResponse = this.responseText;
                        document.getElementById("ResponseText").innerHTML = SearchResponse;

                        var obj = JSON.parse(SearchResponse);
                        var city_name = obj["name"];
                        var country_name = obj["sys"]["country"]; 
                        var weather_description = obj["weather"][0]["description"]; 
                        var temp = obj["main"]["temp"]; 
                        var pressure = obj["main"]["pressure"];
                        var wind_speed = obj["wind"]["speed"];

                        var SearchResultsHTML = "City: " + city_name + "<br />" +
                                                "Country: " + country_name + "<br />" +
                                                "Weather: " + weather_description + "<br />" +
                                                "Temperature: " + temp + "<br />" +
                                                "Pressure: " + pressure + "<br />" +
                                                "Wind Speed: " + wind_speed + "<br />";

                        $("#SearchResults").html(SearchResultsHTML);
                    }
                }



                var Firstbox = $("#Firstbox").val();
                var Secondbox = $("#Secondbox").val();

                var apiKey = "52453f34dee0d65b1a41a02656142c6b";

                if (inputType==1) {
                    var SearchString = "http://api.openweathermap.org/data/2.5/weather" + 
                                       "?q=" + Firstbox + "," + Secondbox + 
                                       "&APPID=" + apiKey;
                } else if (inputType==2) {
                    var SearchString = "http://api.openweathermap.org/data/2.5/weather" + 
                                       "?zip=" + Firstbox + "," + Secondbox + 
                                       "&APPID=" + apiKey;
                } else if (inputType==3) {
                    var SearchString = "http://api.openweathermap.org/data/2.5/weather" + 
                                       "?lat=" + Firstbox + "&lon=" + Secondbox + 
                                       "&APPID=" + apiKey;
                }

                xhttp.open("GET", SearchString, true);
                xhttp.send();
            }
        });

        function checkValidity() {
            var first = document.getElementById('Firstbox');
            var second = document.getElementById('Secondbox');
            var a
            if (first.validity.valid && second.validity.valid) {
                alert('a');
                return a=true;
            } else {

                return a=false;
            }
            return a
        }
    });
...