1

テキストボックスを介して受信したユーザー入力を送信してから、その入力を別のファイル(myfile.js)であるjavascriptに送信しようとしています。何らかの理由で、html部分が機能していません。コードは次のとおりです。myfile.js:

var TRange=null;

function findString (str) {
 if (parseInt(navigator.appVersion)<4) return;
 var strFound;
 if (window.find) {

  // CODE FOR BROWSERS THAT SUPPORT window.find

  strFound=self.find(str);
  if (!strFound) {
   strFound=self.find(str,0,1);
   while (self.find(str,0,1)) continue;
  }
 }
 else if (navigator.appName.indexOf("Microsoft")!=-1) {

  // EXPLORER-SPECIFIC CODE

  if (TRange!=null) {
   TRange.collapse(false);
   strFound=TRange.findText(str);
   if (strFound) TRange.select();
  }
  if (TRange==null || strFound==0) {
   TRange=self.document.body.createTextRange();
   strFound=TRange.findText(str);
   if (strFound) TRange.select();
  }
 }
 else if (navigator.appName=="Opera") {
  alert ("Opera browsers not supported, sorry...")
  return;
 }
 if (!strFound) alert ("String '"+str+"' not found!")
 return;
}

search.html

<!DOCTYPE html>
<HTML>
<HEAD>
</head>
<title>Search</title>
<body>
<script src="myfile.js" type="text/javascript"></script>
<form name="input">

Search for: <input type="text" id ="keytex" name="keytext" onClick='if(document.getElementById("keytex").value!=\'\') findString(document.getElementById("keytex").value); return(false);'>
</form>
<p> You can search this text. Search the text again</p>
</body>
</html>
4

2 に答える 2

1

えーと…HTMLもチェックしましたか?(コードには多くのエラーがあります。これが1つです。)

<input onClick='if(document.getElementById("keytex").value!=\'\') findString(document.getElementById("keytex").value); return(false);'>

それらを見\'ますか?HTMLではそれを行うことはできません。さらに、インラインコードでは角かっこを使用します。 if(){}

これは機能するはずです:

if(document.getElementById("keytex").value!="")

PS:インラインJavaScriptを使用しないでください。彼らはあなたに最後にもっと厄介なHTMLを与えるだけです。

//Good
document.querySelector("#keytex").addEventListener("click",function(){
    if(this.value!=""){             //Use "this" to refer back the element.
        findString(this.value);
    }
    return false;
});

詳細:

于 2012-07-20T01:34:07.323 に答える
0

onclickではなくonchangeまたはonkeyupイベントを使用したい場合があります

于 2012-07-20T01:06:25.213 に答える