いま、下のような状態で作成しています。
<html lung="ja">
<head>
<title>参考資料</title>
</head>
<body>
<!--search-->
<form method="get" action="" name="search">
<div class="search">キーワード検索(キーワード入力>「Search」押下)・・・赤く反転したところが、該当箇所です<br />
<input id="search" name="search" size="20" style="width:300px" class="form" />
<input type="hidden" name="mySearch" value="" />
<input type="button" value="Search" class="button" onClick="javascript:doSearch()" />
</div>
</form>
<pre>
・
・
・
</pre>
<script type="text/javascript" language="javascript">
<!--
// フォント(font = "" などを指定する)
var fontName = "";
// フォントカラー(変更しない場合は、fontColor = "" とする)
var fontColor = "";
// フォントサイズ(単位はpx、変更しない場合は 0 を指定する)
var fontSize = 0;
// 太字(0:太字にしない、1:太字にする)
var isBold = 0;
// 斜体(0:斜体にしない、1:斜体にする)
var isItalic = 0;
// 下線(0:下線をつけない、1:下線をつける)
var isUnderline = 0;
// 背景色(変更しない場合は、backColor = "" とする)
var backColor = "#FF8080";
searchWordHighlighting();
function searchWordHighlighting() {
if (!document.body.createTextRange) return;
var range = document.body.createTextRange();
var searchStr = getSearchStr();
if (searchStr == "") return;
range.collapse(true);
while (range.findText(searchStr)){
if (fontName != "") range.execCommand("fontName", true, fontName);
if (fontSize > 0) range.execCommand("fontSize", true, fontSize);
if (fontColor != "") range.execCommand("foreColor", true, fontColor);
if (isBold != 0) range.execCommand("bold");
if (isItalic != 0) range.execCommand("italic");
if (isUnderline != 0) range.execCommand("underline");
if (backColor != "") range.execCommand("backColor", false, backColor);
range.collapse(false);
}
}
function getSearchStr() {
var urlStr = "" + window.location;
var baseStr = "mySearch=";
var index = urlStr.indexOf(baseStr);
if (index == -1) return "";
urlStr = urlStr.split("%25");
urlStr = urlStr.join("%");
return decodeURIComponent((urlStr.substring(index + baseStr.length)).replace("%25", "%"));
}
function doSearch() {
window.document.search.mySearch.value=encodeURIComponent(window.document.search.search.value);
window.document.search.submit();
}
//-->
</script>
</body>
</html>
これに「Serch」クリック後、該当箇所にジャンプする機能を付けたいです。
教えていただければ幸いです。
宜しくお願いします。
No.2ベストアンサー
- 回答日時:
良かったら参考にしてください。
<html lung="ja">
<head>
<title>参考資料</title>
</head>
<body>
<!--search-->
<form method="get" action="" name="search">
<div class="search">キーワード検索(キーワード入力>「Search」押下)・・・赤く反転したところが、該当箇所です<br />
<input id="search" name="search" size="20" style="width:300px" onkeyup="nCurrentPos=0" />
<input type="button" value="Search" class="button" onClick="javascript:searchWordHighlighting()" />
</div>
</form>
<pre id="target">
・
・
・
</pre>
<script type="text/javascript" language="javascript">
<!--
// フォント(font = "" などを指定する)
var fontName = "";
// フォントカラー(変更しない場合は、fontColor = "" とする)
var fontColor = "";
// フォントサイズ(単位はpx、変更しない場合は 0 を指定する)
var fontSize = 0;
// 太字(0:太字にしない、1:太字にする)
var isBold = 0;
// 斜体(0:斜体にしない、1:斜体にする)
var isItalic = 0;
// 下線(0:下線をつけない、1:下線をつける)
var isUnderline = 0;
// 背景色(変更しない場合は、backColor = "" とする)
var backColor = "#FF8080";
var currentBackColor = "#FFFF00";
var defaultCondition = document.all.tags("PRE")[0].outerHTML;
var nCurrentPos = 0;
function searchWordHighlighting()
{
//フォントをクリア
document.all.tags("PRE")[0].outerHTML = defaultCondition;
if (!document.body.createTextRange) return;
var range = document.body.createTextRange();
var searchStr = window.document.search.search.value;
if (searchStr == "") return;
range.collapse(true);
var nSerachPos = 0;
while (range.findText(searchStr))
{
if (fontName != "") range.execCommand("fontName", true, fontName);
if (fontSize > 0) range.execCommand("fontSize", true, fontSize);
if (fontColor != "") range.execCommand("foreColor", true, fontColor);
if (isBold != 0) range.execCommand("bold");
if (isItalic != 0) range.execCommand("italic");
if (isUnderline != 0) range.execCommand("underline");
if (backColor != "") range.execCommand("backColor", false, backColor);
if( nSerachPos == nCurrentPos )
{
range.execCommand("backColor", false, currentBackColor);
range.scrollIntoView();
}
nSerachPos++;
range.collapse(false);
}
nCurrentPos++;
if( nSerachPos <= nCurrentPos )
nCurrentPos = 0;
}
//-->
</script>
</body>
</html>
No.1
- 回答日時:
boundingTopが使えそう。
function searchWordHighlighting() {
var boundingTop = 0;
...
while (range.findText(searchStr)){
if (boundingTop === 0) boundingTop = range.boundingTop; // 最初に見付かった位置
...
}
window.scrollTo(0, boundingTop); // スクロール
}
boundingTop
http://msdn.microsoft.com/ja-jp/library/cc409787 …
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript 1日1回引けるJavaScriptおみくじについて 1 2022/12/12 22:28
- JavaScript コードレビューをお願いします。 1 2022/07/16 05:38
- JavaScript 画像の表示位置 3 2022/12/23 08:25
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- JavaScript フォームが空欄の時にフォームの外をクリックすると、エラーが出るコードを調べています。 1 2023/06/25 11:51
- HTML・CSS ボタンをクリックした時に、入力フォームのすぐ下部に、「入力欄が空白です」というテキストメッセージが表 1 2022/04/27 16:25
- JavaScript jQueryでのドラッグアンドドロップについて 1 2022/07/07 21:04
- JavaScript スマフォではボタンを表示させたくない 2 2023/01/20 14:26
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
jQueryのload()を使用して外部...
-
google apps scriptの終了のさせ方
-
C#OpenCv V4にのエラーに関する...
-
Javaで避けるゲームを作ってい...
-
【JavaScript】数当てゲームを...
-
C#で、ContextMenuStripに動的...
-
javaScript textareaの一行あた...
-
翌月を取得するGASが分かりません
-
ASP.NETのコントロールの値をJa...
-
javascriptにお詳しい方に質問...
-
商品コードを入力で、商品名、...
-
JavaScriptで決まった「時刻」...
-
ホームページの最終更新日を他...
-
C# 演算 奇数と偶数 表現の仕方
-
特定のclassを表示、非表示にする
-
なぜmatchメソッドがエラーにな...
-
javascriptでカウントダウンタ...
-
ASP.NET MVCでObjectをjsに渡す
-
idを使わずにonclickで自身の要...
-
Linux バイナリ実行できない "...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
google apps scriptの終了のさせ方
-
C#OpenCv V4にのエラーに関する...
-
メールフォームの日付入力フォ...
-
GASでundefinedエラーが出ます
-
ジェネレーターの作り方
-
GASでGoogleフォームの自動返信...
-
なぜmatchメソッドがエラーにな...
-
翌月を取得するGASが分かりません
-
ローカルにあるファイルを検索...
-
HTMLで作った時報アプリが動き...
-
ASP.NETのコントロールの値をJa...
-
C# 演算 奇数と偶数 表現の仕方
-
html javascript リンク先アド...
-
gas スプレッドシートがアクテ...
-
javascriptでテーブルに追加し...
-
VSCODE[Python]の設定について
-
JavaScriptで決まった「時刻」...
-
ASP.NET MVCでObjectをjsに渡す
-
イベントが初めの一回しか起き...
-
jqGridについて
おすすめ情報