PDA

View Full Version : من چطوری کاری که این صفحه میکنه رو بکنم (search)



hamed_bostan
جمعه 19 اسفند 1384, 12:16 عصر
با سلام خدمت اساتید خودم
من میخوام این کاری رو بکنم که توی این صفحه با زدن کلید ها میکنه
http://www.nsftools.com/misc/SearchAndHighlight.htm
روی این لینک کلید کنید و بعد ببینید چطوری توی صفحه به صورت کلاینتی search می کنه . کسی می تونه کمکم کنه از چه راهی باید وارد شم واسه این کار . خیلی فوریه ممنون می شم یه کمک اساسی بکنید

یا حق

meandyouwith2003
جمعه 19 اسفند 1384, 16:38 عصر
عزیز جان ، روی صفحه راست کلیک کن و گزینه View Source را انتخاب کن .
کدهاش javascript هست ولی خیلی راحت میشه فهمید چیکار کرده
موفق باشی .

hamed_bostan
جمعه 19 اسفند 1384, 17:12 عصر
دوست عزیز مشکل اینه که من اصلا جاوا اسکریپت بلد نیستم و نمی دونم این تو کدش چیکار کرده . اخه من می خوام اگه بشه اینو تو یه فایل چاوا اسکریپتی save کنم تو شاخه پروژه و صداش بزنم و ...
واقعیتش یه چیزی تو مایه های چستجوی کلاینتی و runtime مرورگر firefox می خوام

meandyouwith2003
جمعه 19 اسفند 1384, 19:22 عصر
کد زیر کار Highlight کردن را انجام میده :
function doHighlight(bodyText, searchTerm, highlightStartTag, highlightEndTag)
{
// the highlightStartTag and highlightEndTag parameters are optional
if ((!highlightStartTag) || (!highlightEndTag)) {
highlightStartTag = "<font style='color:blue; background-color:yellow;'>";
highlightEndTag = "</font>";
}

// find all occurences of the search term in the given text,
// and add some "highlight" tags to them (we're not using a
// regular expression search, because we want to filter out
// matches that occur within HTML tags and script blocks, so
// we have to do a little extra validation)
var newText = "";
var i = -1;
var lcSearchTerm = searchTerm.toLowerCase();
var lcBodyText = bodyText.toLowerCase();

while (bodyText.length > 0) {
i = lcBodyText.indexOf(lcSearchTerm, i+1);
if (i < 0) {
newText += bodyText;
bodyText = "";
} else {
// skip anything inside an HTML tag
if (bodyText.lastIndexOf(">", i) >= bodyText.lastIndexOf("<", i)) {
// skip anything inside a <script> block
if (lcBodyText.lastIndexOf("/script>", i) >= lcBodyText.lastIndexOf("<script", i)) {
newText += bodyText.substring(0, i) + highlightStartTag + bodyText.substr(i, searchTerm.length) + highlightEndTag;
bodyText = bodyText.substr(i + searchTerm.length);
lcBodyText = bodyText.toLowerCase();
i = -1;
}
}
}
}

return newText;
}



این کد هم کار دکمه highlightSearchTerms را انجام میده :

function highlightSearchTerms(searchText, treatAsPhrase, warnOnFailure, highlightStartTag, highlightEndTag)
{
// if the treatAsPhrase parameter is true, then we should search for
// the entire phrase that was entered; otherwise, we will split the
// search string so that each word is searched for and highlighted
// individually
if (treatAsPhrase) {
searchArray = [searchText];
} else {
searchArray = searchText.split(" ");
}

if (!document.body || typeof(document.body.innerHTML) == "undefined") {
if (warnOnFailure) {
alert("Sorry, for some reason the text of this page is unavailable. Searching will not work.");
}
return false;
}

var bodyText = document.body.innerHTML;
for (var i = 0; i < searchArray.length; i++) {
bodyText = doHighlight(bodyText, searchArray[i], highlightStartTag, highlightEndTag);
}

document.body.innerHTML = bodyText;
return true;
}


این Function هم کار نمایش InputBox ها و MessageBox را انجام میده :

function searchPrompt(defaultText, treatAsPhrase, textColor, bgColor)
{
// This function prompts the user for any words that should
// be highlighted on this web page
if (!defaultText) {
defaultText = "";
}

// we can optionally use our own highlight tag values
if ((!textColor) || (!bgColor)) {
highlightStartTag = "";
highlightEndTag = "";
} else {
highlightStartTag = "<font style='color:" + textColor + "; background-color:" + bgColor + ";'>";
highlightEndTag = "</font>";
}

if (treatAsPhrase) {
promptText = "Please enter the phrase you'd like to search for:";
} else {
promptText = "Please enter the words you'd like to search for, separated by spaces:";
}

searchText = prompt(promptText, defaultText);

if (!searchText) {
alert("No search terms were entered. Exiting function.");
return false;
}

return highlightSearchTerms(searchText, treatAsPhrase, true, highlightStartTag, highlightEndTag);
}


امیدارم بدرت خورده باشه

hamed_bostan
دوشنبه 22 اسفند 1384, 20:07 عصر
ممنونم از لطفتون