特色栏目

ASP源码

PHP源码

.NET源码

JSP源码

游戏频道
专题合集
关闭菜单
首页> WEB标准化> OpenSearch应用初探

OpenSearch应用初探

时间:2009-05-31 01:02:24 作者:互联网

很多现代的浏览器在地址栏的右边有个搜索框,默认的安装有 Google 搜索等。如下图所示:

其实这是 OpenSearch 的一个应用,只要编写相应的微格式的 xml 文件,就可以制定相应的搜索框。参考 OpenSearch 的定义文档,可以基本获得基本的 xml 格式。比如某个典型的的搜索 xml 文件可以这样指定。


http://a9***/-/spec/opensearch/1.1/
">
    utf-8
    ShortName
    Description
    im***/vnd.microsoft.icon">favicon
    http://wh***.i/search?word={searchTerms}"/>
 

上面的 xml 文件很容易理解,除了固定的 xml 根以外,其他的定义从字面上就可以理解:

编写 OpenSearch 的 xml 格式就完成了,详细信息可以参阅其 OpenSearch 定义文档。下面要在页面中加入这个搜索,基本上可以分为两种方式。分别是页面的在 head 中加入 link 标记(类似 RSS),以及使用 Javascript 方式添加(比如定义某个按钮触发)。加入 link 标记非常简单,格式如下

            href="http://wh***.i/search.xml" title="ShortName" />

与 RSS 相似,rel 和 type 是固定的,我们主要指定 href (上述 xml 的 url 路径,保险起见使用绝对路径,即 http:// 开头)以及 title (也就是搜索的短标题)即可。就这样,在 Explorer 以及 Firefox 中打开这个页面就可以看见相应的菜单了,如图所示:

使用 Javascript 添加比较麻烦(或许现在的情况会很好多)。我们主要会使用浏览器的扩展功能,在 Explorer 有个 wi***w.external.AddSearchProvider 参数(详细文档)。典型的调用方法如下

wi***w.external.AddSearchProvider('http://wh***.i/search.xml');

参数中的链接就是上述 link 中的内容。在 Firefox 下可以使用

wi***w.sidebar.addSearchEngine(
    "http://wh***.i/search.xml", /* engine URL */
    "fa***on.ico",  /* icon URL */
    "ShortName", /* engine name */
    "Description" ); /* category name */

参数和例子如示例代码中所述(官方文档)。值得注意的是在 Firefox2 版本以后已经“兼容” Explorer 的 wi***w.external.AddSearchProvider 调用方法(详细信息)。那么我们对应的 Javascript 代码就可以这样编写(为了兼容 Firefox2 之前的版本,加入 else if 判断,如果觉得没有必要,可以不加)

function addEngine(){
    if (wi***w.external || wi***w.external.AddSearchProvider) {
        wi***w.external.AddSearchProvider('http://wh***.i/search.xml');
    } else if (wi***w.sidebar && wi***w.sidebar.addSearchEngine) {
                wi***w.sidebar.addSearchEngine(
                    "http://wh***.i/search.xml",
                    "fa***on.ico",  /* icon URL */
                    "ShortName", /* engine name */
                    "Description" ); /* category name */
    }}

这样,就可以将这个函数注册到某个链接或者按钮的点击事件中,就会跳出个确认框,如图用户点击确认以后,就加入到浏览器搜索框中了。

相关文章

相关应用

热门文章

猜你喜欢

返回顶部