複数のキーワードを入力することであるデータを検索するようにしたいのですがうまくいきません。
以下のプログラムで一つのキーワードで検索するとこまではできました。
<html> <head><title>検索プログラム</title> <script language="JavaScript"> function searchProg(){ var doc = new ActiveXObject("Msxml2.DOMDocument"); doc.async = false; doc.load("hogeA.xml"); var root = doc.documentElement; var string = "<p>"; var searchKey1 = document.form1.key1.value; if(searchKey1 !=""){ var xPath = "movie[year = '"+searchKey1+"']/first"; var results = root.selectNodes(xPath); if(results.length >0){ for(i=0; i<results.length; i++){ string += results.item(i).text+"<br/>"; } }else{ string += "何も検索されませんでした。<br/>"; } }else{ string+= "firstまたはcomicを入力してください。<br/>"; } string += "</p>"; result.innerHTML = string; } </script> </head> <body> <h3>検索プログラム</h3> <form name="form1"> キーワード(firstを入力): <input size="30" type="text" name="key1"/> </form> <input type="button" value="検索" onClick = "searchProg()"> <hr/> 検索結果:<div id="result"></div> </body> </html>
このプログラムを修正してフォームを二つ表示するところまではいけました。
自分でも色々調べてみてand検索、or検索でやるところまではわかったんですがどのようにプログラムを置いていったらいいかわかりません。
参考までに上のプログラムを修正したものも載せておきます。
<html> <head><title>検索プログラム</title> <script language="JavaScript"> function searchProg(){ var doc = new ActiveXObject("Msxml2.DOMDocument"); doc.async = false; doc.load("hogeA.xml"); var root = doc.documentElement; var string = "<p>"; var searchKey1 = document.form1.key1.value; var searchKey2 = document.form2.key2.value; if(searchKey1 !=""){ var xPath = "movie[year = '"+searchKey1+"']/first"; var results = root.selectNodes(xPath); if(results.length >0){ for(i=0; i<results.length; i++){ string += results.item(i).text+"<br/>"; } }else{ string += "何も検索されませんでした。<br/>"; } }else{ string+= "firstまたはcomicを入力してください。<br/>"; } else if(searchKey2 !=""){ var xPath = "movie[comic = '"+searchKey2+"']/first"; var results = root.selectNodes(xPath); if(results.length >0){ for(i=0; i<results.length; i++){ string += results.item(i).text+"<br/>"; } }else{ string += "何も検索されませんでした。<br/>"; } }else{ string+= "firstまたはcomicを入力してください。<br/>"; } string += "</p>"; result.innerHTML = string; } </script> </head> <body> <h3>検索プログラム</h3> <form name="form1"> キーワード(firstを入力): <input size="30" type="text" name="key1"/> </form> <form name="form2"> キーワード(comicを入力): <input size="30" type="text" name="key2"/> </form> <input type="button" value="検索" onClick = "searchProg()"> <hr/> 検索結果:<div id="result"></div> </body> </html>
var xPath = "movie[date/year = '"+searchKey1+"' or comic = '"+searchKey2+"']/first";
に修正することで二つのキーワードで検索はできるようになったのですが
}else{ string += "何も検索されませんでした。<br/>"; } }else{ string+= "firstまたはcomicを入力してください。<br/>"; }
が二つ目の入力フォームに反映されません。
どうしたろよいのでしょうか。
ご指摘、ご教授の方よろしくお願いします。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。