1

我正在尝试为 webbrowser 控件中显示的文本实现搜索功能。我有一个搜索功能可以正常工作以突出显示文本,尽管它目前通过在 web 浏览器中的 javascript 中创建一个搜索栏来实现这一点。这样做的问题是,根据页面的大小,javascript搜索栏的大小总是不同的,这非常令人困惑。我希望能够将用户在我的 WP7 应用程序的文本框中输入的搜索值传递给这个 javascript 函数,然后让它简单地突出显示这些值。我不知道如何将值传递给 javascript 函数,而且我在完成这项工作时遇到了很多困难。

Javascript 搜索功能(在文本文件中)

javascript:(
function()
{
function G()
{
    var pf=doc.getElementById('pf');
    var qt=doc.getElementById('qt');
    if(null==pf)
    {
        pf=doc.createElement('div');
        pf.id='pf';
        var s=pf.style;
        s.position='absolute';
        s.zIndex='99';
        s.top=(scT||scBT)+'px';
        s.left=(scL||scBL)+'px';
        s.width='100%';
        s.backgroundColor='#FFFF00';
        pf.appendChild(doc.createTextNode('Search: '));
        qt=doc.createElement('input');
        qt.id='qt';
        qt.type='text';
        pf.appendChild(qt);
        var sb=doc.createElement('input');
        sb.type='button';
        sb.value='Find';
        sb.onclick=function()
        {
            P(qt.value)
        };
        pf.appendChild(sb);
        doc.body.appendChild(pf);
    }
    else
    {
        pf.style.display='inline';
        count=0;
    }
}
function P(s)
{
    document.getElementById('pf').style.display='none';
    if(s==='')
        return;
    var n=srchNode(document.body,s.toUpperCase(),s.length);
    alert("Found "+count+" occurrence"+(count==1?"":"s")+" of '"+s+"'.");
    pf.parentNode.removeChild(pf);
    return n;
}
function srchNode(node,te,len)
{
    var pos,skip,spannode,middlebit,endbit,middleclone;
    skip=0;
    if(node.nodeType==3)
    {
        pos=node.data.toUpperCase().indexOf(te);
        if(pos>=0)
        {
            spannode=document.createElement("SPAN");
            spannode.style.backgroundColor="red";
            middlebit=node.splitText(pos);
            endbit=middlebit.splitText(len);
            middleclone=middlebit.cloneNode(true);
            spannode.appendChild(middleclone);
            middlebit.parentNode.replaceChild(spannode,middlebit);
            ++count;
            skip=1;
            }
        }
        else
        {
            if(node.nodeType==1&&node.childNodes&&node.tagName.toUpperCase()!="SCRIPT"&&node.tagName.toUpperCase!="STYLE")
            {
                for(var child=0;child<node.childNodes.length;++child)
                {
                    child=child+srchNode(node.childNodes[child],te,len);
                }
            }
        }
        return skip;
    }
    var count=0,scL=0,scT=0,scBL=0,scBT=0;
    var w=window,doc=document;
    if(typeof doc.body!='undefined'&&typeof doc.body.scrollLeft!='undefined')
    {
        scBL=doc.body.scrollLeft;
        scBT=doc.body.scrollTop;
    }
    if(typeof doc.documentElement!='undefined'&&typeof doc.documentElement.scrollLeft!='undefined')
    {
        scL=doc.documentElement.scrollLeft;
        scT=doc.documentElement.scrollTop;
    }
    G();
})()

在页面上查找方法

public void FindOnPage()
    {
        var resource = Application.GetResourceStream(new Uri("Resources/FindOnPage/FindOnPage.txt", UriKind.Relative));
        string text;
        StreamReader sr = new StreamReader(resource.Stream);

        //while((text = sr.ReadToEnd()) != null) 
        if ((text = sr.ReadToEnd()) != null)
        {
            TheWebBrowser.InvokeScript("eval", text);
        } 
    }

假设我有一个名为SearchBar的搜索栏,我将如何通过 javascript 函数将文本传递给用户输入,以便突出显示文本?我没有使用 javascript 的经验,因此我们将不胜感激任何帮助!

4

1 回答 1

0

There is no direct way of passing it. You can string replace the parameter before calling eval, first modify your javascript like this

javascript:(
function(searchString)
{
function P(s)
{
    if(s==='')
        return;
    var n=srchNode(document.body,s.toUpperCase(),s.length);
    alert("Found "+count+" occurrence"+(count==1?"":"s")+" of '"+s+"'.");
    return n;
}
function srchNode(node,te,len)
{
    var pos,skip,spannode,middlebit,endbit,middleclone;
    skip=0;
    if(node.nodeType==3)
    {
        pos=node.data.toUpperCase().indexOf(te);
        if(pos>=0)
        {
            spannode=document.createElement("SPAN");
            spannode.style.backgroundColor="red";
            middlebit=node.splitText(pos);
            endbit=middlebit.splitText(len);
            middleclone=middlebit.cloneNode(true);
            spannode.appendChild(middleclone);
            middlebit.parentNode.replaceChild(spannode,middlebit);
            ++count;
            skip=1;
            }
        }
        else
        {
            if(node.nodeType==1&&node.childNodes&&node.tagName.toUpperCase()!="SCRIPT"&&node.tagName.toUpperCase!="STYLE")
            {
                for(var child=0;child<node.childNodes.length;++child)
                {
                    child=child+srchNode(node.childNodes[child],te,len);
                }
            }
        }
        return skip;
    }
    var count=0,scL=0,scT=0,scBL=0,scBT=0;
    var w=window,doc=document;
    if(typeof doc.body!='undefined'&&typeof doc.body.scrollLeft!='undefined')
    {
        scBL=doc.body.scrollLeft;
        scBT=doc.body.scrollTop;
    }
    if(typeof doc.documentElement!='undefined'&&typeof doc.documentElement.scrollLeft!='undefined')
    {
        scL=doc.documentElement.scrollLeft;
        scT=doc.documentElement.scrollTop;
    }
    P(searchString);
})("#search#")

Then in your C# replace #search# with your SearchString.

public void FindOnPage()
    {
        var resource = Application.GetResourceStream(new Uri("Resources/FindOnPage/FindOnPage.txt", UriKind.Relative));
        string text;
        StreamReader sr = new StreamReader(resource.Stream);

        //while((text = sr.ReadToEnd()) != null) 
        if ((text = sr.ReadToEnd()) != null)
        {
        text = text.Replace("#search#",SearchBar.Text); //Replace SearchBar.Text with the string you want to search    
        TheWebBrowser.InvokeScript("eval", text);
        } 
    }
于 2012-09-21T16:27:51.773 回答