Jump to content
  • 0

Вопрос по null


bangmother
 Share

Question

Только начал изучать Javascript и вот возник вопрос.

Есть код

<script type="text/javascript">

var name = prompt("Введите своё имя","");

if ( !name )

name = "незнакомец";

var s = ("<h1>Привет, "+name+"!</h1>");

document.write(s);

</script>

Хочу что бы человек вводил свое имя. Если вводит, то выводится сообщение "Привет, "имя"". А если не вводит то выводится "Привет, незнакомец".

Теперь вопрос

Почему когда человек нажимает "Отмена" или на крестик, то выводится "Привет, null" / Я думал что (!name) = не имя, тоесть false/// null же является false чего он выводится, а не "незнакомец" ???

Тут такая же ерунда

<script type="text/javascript">

var name;

do

{

name = prompt ("Введите ваше имя","");

}while ( !name )

var s = ("<h1>Привет, "+name+"!</h1>");

document.write(s);

</script>

Link to comment
Share on other sites

9 answers to this question

Recommended Posts

  • 0

Интересно в чем же там может быть загвоздка у ТС, поскольку у меня все выводится как надо. Особенно интересно как может null выводиться во втором случае, если поле пустым нельзя оставить..

Link to comment
Share on other sites

  • 0

prompt возвращает строку "null" если нажать отмена. По этому и не получается.

<script>

var name = prompt("Введите своё имя","");

if (name == "null" || name == "")
name = "незнакомец";

var s = ("<h1>Привет, "+name+"!</h1>");
document.write(s);
</script>

У меня только так получилось заставить его работать как надо.

Edited by Duddits
Link to comment
Share on other sites

  • 0

Нарыл такое

Нельзя использовать переменную name

Она уже есть в глобальной области видимости до Вас.

И Chrome принудительно приводит ее к строке, чтобы вы туда не пытались положить.

Потому вариант


var vname = prompt("Введите своё имя","");
if (!vname) {
vname = "незнакомец";
}
var s = ("<h1>Привет, "+vname+"!</h1>");
document.write(s);

работает. А так вы лишаете имени пользователя с ником null :mellow:

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

 Share

  • Обсуждения

    • Вот тут есть актуальный список бесплатных тестов с сертификацией https://www.classcentral.com/report/free-certificates/ Обратите внимание на HackerRank, там есть тест с сертификацией непосредственно по CSS
    • Нужно сверстать по картинке меню-бар. Не получается сделать вот это поле поиска <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <meta http-equiv="X-UA-Compatible" content="IE=edge">     <meta name="viewport" content="width=device-width, initial-scale=1.0">     <title>Document</title>     <style> .nav {     display: flex;     list-style-type: none;     padding-left: 0;     font-size: 17px;     text-transform: uppercase; } .nav > li > a {     color: #fff;     text-decoration: none; } .nav > li {     padding-left: 29px;     margin-left: 30px; } .header {     display: flex;     background-color: #31485b;     justify-content: space-between;     align-items: center; }   .sidebar {     width: 410px;     display: block;     padding-right: 20px;     margin: auto;     margin-left: 250px; }   ul.nav li a:hover {     background-color: #687c8d;     padding: 17.2px 35px; }   input[type="text"], input[type="search"] {   background-color: #687c8d;   width: 60%;   padding: 8px;   margin: 0 50px }   input[type="search"] {     color: #31485b;     font-style: italic; }     </style> </head> <body>     <div class="header">                 <ul class="nav">                     <li class="s1"><a href="#">Главная</a></li>                     <li><a href="#">Блог</a></li>                     <li><a href="#">Сервисы</a></li>                     <li><a href="#">Онлайн-профессии</a></li>                     <li><a href="#">О сайте</a></li>                 </ul>                                 <div class="sidebar">                     <form method="post" action="#" id="search_form" >                       <input type="search" name="search_field" placeholder="Поиск" />                     </form>                   </div>     </div> </body> </html>  
    • ЭЭ, а почему оно должно удалять? Может стоило повесить событие на эту кнопку и указать, что при это должно происходить?
    • например -R не будет качать указанные файлы если вы знаете список нужных вам файлов, проще их указать или можно написать парсер
    • выкладывайте код в песочнице, так будет проще У вас media подключается до blocks/header, по этому правила из blocks/header перекрывают media сверху вниз в css пишите tag .class ... @media и не будет у вас подобных проблем  
×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue. See more about our Guidelines and Privacy Policy