Понимание попытки.. выгода в JavaScript

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

var pg = new Object();
var da = document.all;
var wo = window.opener;

pg.changeHideReasonID = function(){
 if(pg.hideReasonID.value == 0 && pg.hideReasonID.selectedIndex > 0){
  pg.otherReason.style.backgroundColor = "ffffff";
  pg.otherReason.disabled = 0;
  pg.otherReason.focus();
 } else {
  pg.otherReason.style.backgroundColor = "f5f5f5";
  pg.otherReason.disabled = 1;
 }
}

pg.exit = function(pid){

 try {
  if(window.opener.hideRecordReload){
   window.opener.hideRecordReload(pg.recordID, pg.recordTypeID);

  } else {
   window.opener.pg.hideRecord(pg.recordID, pg.recordTypeID);

  }
 } catch(e) {}
 try {
  window.opener.pg.hideEncounter(pg.recordID);

 } catch(e) {}
 try {
  window.opener.pg.hideRecordResponse(pg.hideReasonID.value == 0 ? pg.otherReason.value : pg.hideReasonID.options[pg.hideReasonID.selectedIndex].text);

 } catch(e) {}
 try {
  window.opener.pg.hideRecord_Response(pg.recordID, pg.recordTypeID);

 } catch(e) {}
 try {
  window.opener.pg.hideRecord_Response(pg.recordID, pg.recordTypeID);

 } catch(e) {}
 try {
  window.opener.window.parent.frames[1].pg.loadQualityMeasureRequest();

 } catch(e) {}
 try {
  window.opener.pg.closeWindow();

 } catch(e) {} 



   parent.loadCenter2({reportName:'redirectedpage',patientID:pid});          
 parent.$.fancybox.close();

}

pg.hideRecord = function(){
      var pid = this.pid;

 pg.otherReason.value = pg.otherReason.value.trim();
 if(pg.hideReasonID.selectedIndex == 0){
  alert("You have not indicated your reason for hiding this record.");
  pg.hideReasonID.focus();
 } else if(pg.hideReasonID.value == 0 && pg.hideReasonID.selectedIndex > 0 && pg.otherReason.value.length < 2){
  alert("You have indicated that you wish to enter a reason\nnot on the list, but you have not entered a reason.");
  pg.otherReason.focus();
 } else {
  pg.workin(1);
  var n = new Object();
  n.noheaders = 1;
  n.recordID = pg.recordID;
  n.recordType = pg.recordType;
  n.recordTypeID = pg.recordTypeID;
  n.encounterID = request.encounterID;
  n.hideReasonID = pg.hideReasonID.value;
  n.hideReason = pg.hideReasonID.value == 0 ? pg.otherReason.value : pg.hideReasonID.options[pg.hideReasonID.selectedIndex].text;

  Connect.Ajax.Post("/emr/hideRecord/act_hideRecord.php", n, pg.exit(pid));


 }
}

pg.init = function(){
 pg.blocker = da.blocker;
 pg.hourglass = da.hourglass;

 pg.content = da.pageContent;

 pg.recordType = da.recordType.value;
 pg.recordID = parseInt(da.recordID.value);
 pg.recordTypeID = parseInt(da.recordTypeID.value);

 pg.information = da.information;

 pg.hideReasonID = da.hideReasonID;
 pg.hideReasonID.onchange = pg.changeHideReasonID;
 pg.hideReasonID.tabIndex = 1;

 pg.otherReason = da.otherReason;
 pg.otherReason.tabIndex = 2;
 pg.otherReason.onblur = function(){
  this.value = this.value.trim();
 }
 pg.otherReason.onfocus = function(){
  this.select();
 }

 pg.btnCancel = da.btnCancel;
 pg.btnCancel.tabIndex = 4;
 pg.btnCancel.title = "Close this window";
 pg.btnCancel.onclick = function(){
  //window.close();
  parent.$.fancybox.close(); 
 }

 pg.btnHide = da.btnHide;
 pg.btnHide.tabIndex = 3;
 pg.btnHide.onclick = pg.hideRecord;
 pg.btnHide.title = "Hide " + pg.recordType.toLowerCase() + " record";

 document.body.onselectstart = function(){
  if(event.srcElement.tagName.search(/INPUT|TEXT/i)){
   return false;
  }
 }

 pg.workin(0);
}

pg.workin = function(){
 var n = arguments.length ? arguments[0] : 1;
 pg.content.disabled = pg.hideReasonID.disabled = n;
 pg.blocker.style.display = pg.hourglass.style.display = n ? "block" : "none";
 if(n){
  pg.otherReason.disabled = 1;
  pg.otherReason.style.backgroundColor = "f5f5f5";
 } else {
  pg.otherReason.disabled = !(pg.hideReasonID.value == 0 && pg.hideReasonID.selectedIndex > 0);
  pg.otherReason.style.backgroundColor = pg.otherReason.disabled ? "f5f5f5" : "ffffff";
  pg.hideReasonID.focus();
 }
}
8
задан Vivin Paliath 15 April 2010 в 16:57
поделиться

2 ответа

Это хорошая практика. что-то делать с отловленными исключениями.

Здесь происходит то, что если возникает ошибка (например, загрузка страницы не удалась), в одном из ваших блоков try генерируется исключение.Соответствующий блок catch захватывает его и сообщает, что «это исключение было обработано», но на самом деле вы ничего с ним не сделали.

Попробуйте поставить печать (e.Message); внутри блоков catch, чтобы узнать, какая именно ошибка приводит к тому, что страница не загружается, а затем добавьте код в блок catch для устранения этой ошибки.

3
ответ дан 5 December 2019 в 07:10
поделиться

Думаю, ваша основная проблема в том, что вы проглатываете исключения, что очень плохо . Поэтому «иногда это срабатывает». Что-то вызывает исключение, и вы его поймаете, но после этого вы больше ничего не делаете. По крайней мере, я бы отобразил какое-то сообщение об ошибке в вашем блоке catch .

Еще несколько проблем:

  • Вы уверены, что вам нужны эти несколько блоков try..catch ? Текущее предположение в вашем коде состоит в том, что каждая строка, заключенная в try..catch , не зависит от других, и выполнение может продолжаться, если что-то пойдет не так в одном (или нескольких) из этих операторов. . Вы уверены, что это то, что вам нужно? Если да, то определенно есть лучший способ справиться с этим.
  • Если операторы не независимы друг от друга, и если сбой в какой-либо момент означает, что выполнение не может продолжиться, то вы можете заключить все эти операторы в один try..catch блок и отображение сообщения об ошибке в catch
  • Как я уже сказал, проглатывание исключений очень плохо ! Вы скрываете проблему и ничего не добиваетесь. Это также чрезвычайно усложняет отладку, потому что все перестанет работать, и вы не поймете, почему (без исключения, без регистрации, без сообщений об ошибках). Исключения используются, когда происходит что-то непредвиденное, прерывающее нормальный ход выполнения программы. Это то, с чем вы обязательно захотите справиться.

Я думаю, что то, что вы хотите, можно сделать следующим образом:

try {
    if(window.opener.hideRecordReload){
        window.opener.hideRecordReload(pg.recordID, pg.recordTypeID);

    } else {
        window.opener.pg.hideRecord(pg.recordID, pg.recordTypeID);

    }

    window.opener.pg.hideEncounter(pg.recordID);
    window.opener.pg.hideRecordResponse(pg.hideReasonID.value == 0 ? pg.otherReason.value : pg.hideReasonID.options[pg.hideReasonID.selectedIndex].text);
    window.opener.pg.hideRecord_Response(pg.recordID, pg.recordTypeID);
    window.opener.pg.hideRecord_Response(pg.recordID, pg.recordTypeID);
    window.opener.window.parent.frames[1].pg.loadQualityMeasureRequest();
    window.opener.pg.closeWindow();

}

catch(e) {
   console.log(e);
}   

Таким образом, если в этой серии операторов возникает исключение, блок catch обработает это.

Javascript также не имеет истинных проверенных исключений. Вы можете обойти это, имея единственный блок попытки и проверив полученный объект исключения * .

В дополнение к тому, о чем я говорил ранее, есть два способа обработки исключений. Первый способ, как я показал ранее, предполагает, что при возникновении исключения код находится в недопустимом / неопределенном состоянии, и это означает, что код обнаружил неисправимую ошибку. Другой способ обработки исключений - это если вы знаете, что от этого можно избавиться. Вы можете сделать это с помощью флага. Итак:

try {
   doSomething();
}

catch(e) {
   error = true;
}

if(error) {
   doStuffToRecoverFromError();
}

else {
   doOtherStuff();
}

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

* Вот несколько надуманный пример, демонстрирующий проверенные исключения. У меня есть два исключения, называемые VeryBadException и ReallyBadException , которые могут быть выброшены (случайным образом) из двух функций. Блок catch обрабатывает исключение и определяет тип исключения, используя оператор instanceof ):

function VeryBadException(message) {
   this.message = message; 
}

function ReallyBadException(message) {
   this.message = message;
}

function foo() {
   var r = Math.floor(Math.random() * 4);
   if(r == 2) {
      throw new VeryBadException("Something very bad happened!");
   }
}

function bar() {
   var r = Math.floor(Math.random() * 4);
   if(r == 1) {
      throw new ReallyBadException("Something REALLY bad happened!");
   }
}

try {
  foo();
  bar();
}

catch(e) {
   if(e instanceof VeryBadException) {
      console.log(e.message);
   }

   else if(e instanceof ReallyBadException) {
      console.log(e.message);
   }
}
20
ответ дан 5 December 2019 в 07:10
поделиться
Другие вопросы по тегам:

Похожие вопросы: