javascript_javascript のヒントにおける、previousSibling と nextSibling の正しい使用法

WBOY
リリース: 2016-05-16 15:39:13
オリジナル
1175 人が閲覧しました

時間検証を行う場合、開始日と終了日のサイズを確認するだけで済みます。ただし、入力ページはバッチで各行が自動的に生成されるため、 id はパラメータとして使用され、ノードのみが使用できます。これにより、検証がより困難になります。

以下は JSP ページの一部です:

<td><input id="warrantyStartDateStr" name="warrantyStartDateStr"        

 class="toolbar_button_input_80" type="Text" onClick="WdatePicker()"></td>
<td><input id="warrantyEndDateStr" name="warrantyEndDateStr" class="toolbar_button_input_80" type="Text" onClick="WdatePicker()" onBlur="checkDateOne(this)"></td>
ログイン後にコピー

そして私の js 関数は最終的に次のように書かれています:

js 関数の目的は、id を渡さずに 2 つの入力、つまり開始時刻と終了時刻の値を取得し、その 2 つの時刻を比較することです。

function checkDateOne(inputsNode){
var p = inputsNode.parentNode; //取得input节点的父节点td
var preNode=p.previousSibling.firstChild;//取得td节点的前一个兄弟节点的第一个子结点
var startDate = document.getElementByIdx_x(preNode.id).value;
var endDate = document.getElementByIdx_x(inputsNode.id).value;      
if(startDate.length>0 && endDate.length>0){   
 var startTmp=startDate.split("-"); 
 var endTmp=endDate.split("-"); 
 var sd=new Date(startTmp[0],startTmp[1],startTmp[2]); 
 var ed=new Date(endTmp[0],endTmp[1],endTmp[2]); 
 if(sd.getDate()>=ed.getDate()){  
  alert("起始日期不能大于结束日期");   
   //return false;   
  }   
  }
 }
ログイン後にコピー

まず、現在のノード入力ノードの親ノード p (つまり、td ノード) を取得し、次に親ノードの前のノードの最初の子ノード入力を取得します。これで目標は達成されました。

ここで強調したいのは、td ノードは入力ノードの親ノードであり、その兄弟ノードとは見なされないことを忘れないでください。

また、IE と FF の間の、previousSibling と nextSibling の違いについても述べておきたいと思います。

まず例を見てみましょう:

<body>  
<div>  
<input id= "a4" type= "button" onclick= "alert(this.nextSibling);" value= "d" />  
<input id= "a5" type= "button" onclick= "alert(this.nextSibling);" value= "e" />  
</div>  
</body> 
ログイン後にコピー

表面的には、このオブジェクトの構造は、div の nextSibling には 2 つの項目 (2 つの入力ノード) だけがあることがわかります。しかし実際には、/n,input,/n,input,/n という 5 つの項目があります。これは、input がさまざまなフォーム入力コントロールを作成するためのラベルとして使用されるためです。ボタン、チェックボックス、ラジオなどのフォーム コントロールを生成する場合でも、IE は最後に 1 バイトの空白を自動的に作成します。

IE はノード間で生成されるスペース ドキュメント ノード (改行文字など) をスキップしますが、Mozilla はこれを行いません。FF はスペース ブレークや改行などのレイアウト要素をノードの読み取りとして扱うため、次のノード要素でIE で nextSibling を使用して読み取ることができるものは、FF では次のように記述する必要があります: nextSibling.nextSibling。

PreviousSibling はまったく逆の効果ですが、使い方は同じです。

次の兄弟と前の兄弟の紹介

FireFox ではテキスト ノードとしてスペースが多く含まれるため、nextSibling とpreviousSibling を使用すると問題が発生します。 FireFox はテキスト ノードを誤って要素ノードの兄弟ノードとして扱うためです。判断するためにnodeTypeを追加することができます。前ノードまたは次ノードがテキストノードの場合は、次の要素ノードが見つかるまで検索を続けます。次のコードは参照専用であり、fireFox でのテストに合格しました:

        //下一个兄弟节点
    function nextSibling(node) {
      var tempLast = node.parentNode.lastChild;
      if (node == tempLast) return null;
      var tempObj = node.nextSibling;
      while (tempObj.nodeType != 1 && tempObj.nextSibling != null) {
        tempObj = tempObj.nextSibling;
      }
      return (tempObj.nodeType==1)&#63; tempObj:null;
    }
    //前一个兄弟节点
    function prevSibling(node) {
      var tempFirst = node.parentNode.firstChild;
      if (node == tempFirst) return null;
      var tempObj = node.previousSibling;
      while (tempObj.nodeType != 1 && tempObj.previousSibling != null) {
        tempObj = tempObj.previousSibling;
      }
      return (tempObj.nodeType==1)&#63; tempObj:null;
    }  

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  <title></title>
  <script type="text/javascript" language="javascript" >
    window.onload = function () {
      var oUl = document.getElementsByTagName("UL");
      var nodeLi = oUl[0].childNodes[3];
      var nextListItem = nodeLi.nextSibling;
      var preListItem = nodeLi.previousSibling;
      alert(nextListItem.tagName + " " + preListItem.tagName);
      nextListItem = nextSibling(nodeLi);
      preListItem = prevSibling(nodeLi);
      alert(nextListItem.tagName + " " + preListItem.tagName);
    }
    //下一个兄弟节点
    function nextSibling(node) {
      var tempLast = node.parentNode.lastChild;
      if (node == tempLast) return null;
      var tempObj = node.nextSibling;
      while (tempObj.nodeType != 1 && tempObj.nextSibling != null) {
        tempObj = tempObj.nextSibling;
      }
      return (tempObj.nodeType==1)&#63; tempObj:null;
    }
    //前一个兄弟节点
    function prevSibling(node) {
      var tempFirst = node.parentNode.firstChild;
      if (node == tempFirst) return null;
      var tempObj = node.previousSibling;
      while (tempObj.nodeType != 1 && tempObj.previousSibling != null) {
        tempObj = tempObj.previousSibling;
      }
      return (tempObj.nodeType==1)&#63; tempObj:null;
    }  
  </script>
</head>
<body>
  <form id="form1" runat="server">
  <div>
    <ul>
      <li>HTML</li>
      <li>CSS</li>
      <li>JavaScript</li>
      <li>JQuery</li>
      <li>Dom</li>
    </ul>
    <ul>
      <li>ASP.NET</li>
      <li>JSP</li>
      <li>PHP</li>
      <li>VB.NET</li>
    </ul>
  </div>
  </form>
</body>
</html>
ログイン後にコピー

nodeType の主な値は次のとおりです:

要素ノードのnodeType値は1です
属性ノードのnodeType値は2
です テキストノードのnodeType値は3

です
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート