Как редактировать заголовок окна предупреждений JavaScript? - PullRequest
160 голосов
/ 15 декабря 2009

Я генерирую предупреждение JavaScript со следующим кодом на странице C # .NET:

Response.Write("<script language=JavaScript> alert('Hi select a valid date'); </script>");

Отображается окно с заголовком «Сообщение с веб-страницы».

Можно ли изменить заголовок?

Ответы [ 11 ]

241 голосов
/ 15 декабря 2009

Нет, вы не можете.

Это функция безопасности / защиты от фишинга.

65 голосов
/ 15 декабря 2009

Нет, это невозможно. Вы можете использовать настраиваемое окно предупреждения JavaScript.

Нашел хороший, используя jQuery

jQuery Alert диалоги (оповещение, подтверждение и быстрые замены)

31 голосов
/ 15 декабря 2009

Вы можете сделать это в IE:

<script language="VBScript">
Sub myAlert(title, content)
      MsgBox content, 0, title
End Sub
</script>

<script type="text/javascript">
myAlert("My custom title", "Some content");
</script>

(хотя, я бы очень хотел, чтобы ты не смог.)

11 голосов
/ 16 ноября 2012

Переопределить функцию javascript window.alert ().

window.alert = function(title, message){
    var myElementToShow = document.getElementById("someElementId");
    myElementToShow.innerHTML = title + "</br>" + message; 
}

С этим вы можете создать свою собственную функцию alert(). Создайте новый «крутой» вид диалога (из некоторых элементов div).

Проверено на работу в Chrome и WebKit, не уверен в других.

9 голосов
/ 27 июля 2016

Я нашел это Sweetalert для настройки javascript поля заголовка.

Например

swal({
  title: "Are you sure?",
  text: "You will not be able to recover this imaginary file!",
  type: "warning",
  showCancelButton: true,
  confirmButtonColor: "#DD6B55",
  confirmButtonText: "Yes, delete it!",
  closeOnConfirm: false
},
function(){
  swal("Deleted!", "Your imaginary file has been deleted.", "success");
});
4 голосов
/ 13 февраля 2013

Здесь есть довольно приятный «хак» - https://stackoverflow.com/a/14565029, где вы используете iframe с пустым src для генерации предупреждающего / подтверждающего сообщения - он не работает на Android (ради безопасности) - но может удовлетворить ваш сценарий.

4 голосов
/ 09 июля 2010

Чтобы ответить на вопросы с точки зрения того, как вы их задали.

Это действительно ДЕЙСТВИТЕЛЬНО легко (по крайней мере, в Internet Explorer), я сделал это за 17,5 секунд.

Если вы используете пользовательский скрипт, предоставленный cxfx: (поместите его в файл apsx)

<script language="VBScript">
Sub myAlert(title, content)
MsgBox content, 0, title 
End Sub 
</script>

Затем вы можете звонить так же, как вы вызывали обычное оповещение. Просто измените свой код следующим образом.

Response.Write("<script language=JavaScript> myAlert('Message Header Here','Hi select a valid date'); </script>");

Надеюсь, это поможет вам или кому-то еще!

2 голосов
/ 02 мая 2016

Вы можете сделать небольшую настройку, чтобы оставить пустую строку вверху.

Вот так.

        <script type="text/javascript" >
            alert("USER NOTICE "  +"\n"
            +"\n"
            +"New users are not allowed to work " +"\n"
            +"with that feature.");
        </script>
1 голос
/ 12 июля 2013

Когда вы запускаете или просто присоединяетесь к проекту на основе веб-приложений, дизайн интерфейса может быть хорошим. В противном случае это должно быть изменено. Для приложений Web 2.0 вы будете работать с динамическим содержимым, множеством эффектов и прочим. Все эти вещи хороши, но никто не задумывался над тем, чтобы создать окно предупреждений JavaScript и подтвердить поля. Вот они, .. полностью динамические, управляемые JS и CSS Создать простой HTML-файл

<html>
 <head>
   <title>jsConfirmSyle</title>
   <meta http-equiv="Content-Style-Type" content="text/css" />
   <meta http-equiv="Content-Script-Type" content="text/javascript" />
    <script type="text/javascript" src="jsConfirmStyle.js"></script>
    <script type="text/javascript">

      function confirmation() {
       var answer = confirm("Wanna visit google?")
       if (answer){
       window.location = "http://www.google.com/";
       }
     }    

    </script>
    <style type="text/css">
     body {
      background-color: white;
      font-family: sans-serif;
      }
    #jsconfirm {
      border-color: #c0c0c0;
      border-width: 2px 4px 4px 2px;
      left: 0;
     margin: 0;
     padding: 0;
     position: absolute;
    top: -1000px;
    z-index: 100;
   }

  #jsconfirm table {
   background-color: #fff;
   border: 2px groove #c0c0c0;
   height: 150px;
   width: 300px;
  }

   #jsconfirmtitle {
  background-color: #B0B0B0;
  font-weight: bold;
  height: 20px;
  text-align: center;
}

 #jsconfirmbuttons {
height: 50px;
text-align: center;
 }

#jsconfirmbuttons input {
background-color: #E9E9CF;
color: #000000;
font-weight: bold;
width: 125px;
height: 33px;
padding-left: 20px;
}

#jsconfirmleft{
background-image: url(left.png);
}

#jsconfirmright{
background-image: url(right.png);
 }
 < /style>
  </head>
 <body>
<p><br />
<a href="#"
onclick="javascript:showConfirm('Please confirm','Are you really really sure to visit    google?','Yes','http://www.google.com','No','#')">JsConfirmStyled</a></p>
<p><a href="#" onclick="confirmation()">standard</a></p>

</body>
</html>

Затем создайте простое имя файла js jsConfirmStyle.js. Вот простой код JS

ie5=(document.getElementById&&document.all&&document.styleSheets)?1:0;
nn6=(document.getElementById&&!document.all)?1:0;

 xConfirmStart=800;
 yConfirmStart=100;

  if(ie5||nn6) {
  if(ie5) cs=2,th=30;
  else cs=0,th=20;
   document.write(
    "<div id='jsconfirm'>"+
        "<table>"+
            "<tr><td id='jsconfirmtitle'></td></tr>"+
            "<tr><td id='jsconfirmcontent'></td></tr>"+
            "<tr><td id='jsconfirmbuttons'>"+
                "<input id='jsconfirmleft' type='button' value='' onclick='leftJsConfirm()' onfocus='if(this.blur)this.blur()'>"+
                "&nbsp;&nbsp;"+
                "<input id='jsconfirmright' type='button' value='' onclick='rightJsConfirm()' onfocus='if(this.blur)this.blur()'>"+
            "</td></tr>"+
        "</table>"+
    "</div>"
  );
   }

 document.write("<div id='jsconfirmfade'></div>");


 function leftJsConfirm() {
  document.getElementById('jsconfirm').style.top=-1000;
  document.location.href=leftJsConfirmUri;
 }
function rightJsConfirm() {
document.getElementById('jsconfirm').style.top=-1000;
document.location.href=rightJsConfirmUri;
 }
function confirmAlternative() {
if(confirm("Scipt requieres a better browser!"))       document.location.href="http://www.mozilla.org";
}

leftJsConfirmUri = '';
rightJsConfirmUri = '';

  /**
   * Show the message/confirm box
  */
    function       showConfirm(confirmtitle,confirmcontent,confirmlefttext,confirmlefturi,confirmrighttext,con      firmrighturi)  {
document.getElementById("jsconfirmtitle").innerHTML=confirmtitle;
document.getElementById("jsconfirmcontent").innerHTML=confirmcontent;
document.getElementById("jsconfirmleft").value=confirmlefttext;
document.getElementById("jsconfirmright").value=confirmrighttext;
leftJsConfirmUri=confirmlefturi;
rightJsConfirmUri=confirmrighturi;
xConfirm=xConfirmStart, yConfirm=yConfirmStart;
if(ie5) {
    document.getElementById("jsconfirm").style.left='25%';
    document.getElementById("jsconfirm").style.top='35%';
}
else if(nn6) {
    document.getElementById("jsconfirm").style.top='25%';
    document.getElementById("jsconfirm").style.left='35%';
}
else confirmAlternative();

}

Вы можете скачать полный исходный код здесь

1 голос
/ 07 сентября 2011

Да, вы можете изменить его. если вы вызываете функцию VBscript в Javascript.

Вот простой пример

<script>

function alert_confirm(){

      customMsgBox("This is my title","how are you?",64,0,0,0);
}

</script>


<script language="VBScript">

Function customMsgBox(tit,mess,icon,buts,defs,mode)
   butVal = icon + buts + defs + mode
   customMsgBox= MsgBox(mess,butVal,tit)
End Function

</script>

<html>

<body>
<a href="javascript:alert_confirm()">Alert</a>
</body>

</html>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...