html中的搜索框怎么做?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了html中的搜索框怎么做?相关的知识,希望对你有一定的参考价值。

<input type="text" class="aa" /><input type="button" value="search" />
.aawidth:100px; height:20px; boder:solid 1px #f00;//定义搜索框的大小高度以及边框颜色。

思路是:
放大镜图标用个img写进来或者用其它标签用CSS做背景也可以;
下拉导航这种效果系统的Select下拉是最容易想到的,但是别想着用它做,,原因很简单,做不到的,,这个必须借助JS辅助来解决!
参考技术A 回答

亲您好很高兴为你解答:为你查询到

html制作一个搜索框,代码是什么?

1、打开Hbuilder编辑器,创建一个input框和button按钮,将它们横排摆放在一起:

2、首先给input框添加“#7FCC0B”颜色的边框,设置宽度和高度即可,给button按钮设置白色的字体和“#7FCC0B”的背景颜色即可完成:

3、按crtl+s,在软件的右侧即可看到最终的效果。以上就是用html制作搜索框的演示:

Symfony2 中的搜索框与 Solr

【中文标题】Symfony2 中的搜索框与 Solr【英文标题】:Search Box in Symfony2 with Solr 【发布时间】:2012-12-12 01:36:20 【问题描述】:

我想在我的网站首页创建搜索框,但我不知道如何使用Solr 创建一个。我所有的网站都是在 Symfony2 中开发的。我不使用数据库进行搜索。

我该怎么做?

在我的项目 Solr 中使用这个:

use SolrClient;
use SolrQuery;
use SolrObject;
use SolrDocument;
use SolrInputDocument;

在基础 twig 文件中:

<form action=" path("home_search") " method="get">
  <input type="search" name="search"><br>
  <input type="submit" value="search">
</form>

我的控制器的一些例子:

public function searchAction($templateName = '')

 $solrService = $this->get('rocket.solr_service');

    $solrQuery = new SolrQuery('*:*');
    $solrQuery->addField('id')
        ->addField('name');


    if (!empty($templateName)) 
        $solrQuery->addFilterQuery(sprintf('name:"%s" OR design_template_tag_name:"%1$s" OR design_category_name:"%1$s"',
                                           $templateName));
    


    $solrQuery->setRows(1000);

    $solrObject = $solrService->query(
        'RocketBraPrintBundle:DesignTemplate',
        $solrQuery,
        SolrService::WRITER_FORMAT_SOLR_OBJECT
    );

    $templates = $solrObject->offsetGet('response')->offsetGet('docs');
    if (!$templates) 

        if (!empty($templateName)) 
            $this->setFlash('catalog-message', 'No results found for your search.');
            return $this->searchDesignTemplates($categoryTreeSlug,
                                                $productFamilyFaceId);
        

        return array();
    

    return $templates;


但是在渲染的树枝文件中,我不知道我会写什么。

【问题讨论】:

您使用什么捆绑软件在 solr 中进行连接和搜索? @ArtemL 感谢您的评论。我正在使用 solr bundle 并且什么都不搜索,因为我是 solr 搜索的新手。 您使用的是什么包?如何?一些鳕鱼可能有助于回答这个问题。 @ArtemL 我已经编辑了我的问题,你可以看到 deps 文件,我没有任何搜索代码。 看不到任何 solr 包。你能指出你已经在使用 solr 的哪个包吗? 【参考方案1】:

您可以将https://github.com/nelmio/NelmioSolariumBundle 与使用日光浴室一起使用

非常适合更好的 solr 查询

我已经用过了

这里是一个示例

    $query = 'foo';

    $page = 1;
    if (array_key_exists('page', $params)) 
        $page = (int) $params['page'];
    
    $rows = 10;
    if (array_key_exists('limit', $params)) 
        $rows = (int) $params['limit'];
    

    $solarium = $this->get('solarium.client');

    //select
    $select = $solarium->createSelect();
    $escapedQuery = $select->getHelper()->escapePhrase($query);

    //dismax
    $dismax = $select->getDisMax();
    // override the default setting of 'dismax' to enable 'edismax'
    $dismax->setQueryParser('edismax');
    //fields
    $dismax->setQueryFields(
                    array('title^5','description^0.7'));

    $select->setQuery($escapedQuery);

    //limit
    $select->setRows($rows);
    $select->setStart(($page - 1) * $rows);

    //type spot only
    $select->createFilterQuery('typeFilter')
            ->setQuery(sprintf('type:%s', 'spot'));

    $resultset = $solarium->select($select);

使用 foreach 或 twig "for in" 来显示你的 solr doc

【讨论】:

我已经设置了日光浴室,并且可以进行如图所示的查询,但是我正在努力尝试为我的文档编制索引。我有一个 Symfony2 注释对象,我有一个方法 toSolrDocument(\Solarium_Document_ReadWrite $doc) 来翻译文档,如 Xavier Briand 的演示文稿中所示。但是,当我这样称呼它时 foreach ($sheets as $sheet) $documents[] = $sheet->toSolrDocument($update->createDocument()); 我得到“Solarium_Document_ReadWrite”没有找到任何想法如何解决这个问题? 很奇怪,你确定你的日光浴室库在你的供应商库中吗?确保您使用的是 solarium 2.4.x,最新版本 3.x 使用 php 5.3 命名空间 我通过删除对读写类的要求解决了这个问题。但是,我有一个具有多个核心的新问题。我在我的 solr 示例安装中设置了多个核心,并将我需要的核心添加到我的 symfony2 配置中,但是,不知何故,我可以访问的默认核心是 sorl.xml 文件中 defaultCoreName 属性下指定的核心。有什么想法吗? 请打开一个新问题,它与搜索框问题无关。谢谢【参考方案2】:

试试这样的..

Controlloer.php:

public function searchAction($templateName = '')

    // ------
    // ------

    $resultset = $solrObject->offsetGet('response');

    // Do some error checks

    return array('resultset'=>$resultset);


树枝:

<ul>
% for doc in resultset %
  <li>  doc.name  </li>
% endfor %
</ul>

【讨论】:

【参考方案3】:

我还没有尝试过,但是您可以尝试在 Symfony2 中使用这个新的Jobeet tutorial,它解释了如何构建系统以及如何在其中使用 Solr。 我希望这会有所帮助。

【讨论】:

【参考方案4】:

您可以通过

获得 GET 参数

$searchName = $request->query->get('search_name');

但是为此,您仍然需要 $request 变量。您可以将其用作参数并将您的方法签名更改为:

公共函数 anagraficaAction(Request $request)

这样,您可以在方法中调用 $request 参数。

另一种方法是在你的方法中获取当前控制器的请求。

$request = $this->get('request');

使用这个你可以把你的 setParameter 改成这个:

setParameter('nome', $searchName)

【讨论】:

以上是关于html中的搜索框怎么做?的主要内容,如果未能解决你的问题,请参考以下文章

html中搜索框怎么做

HTML5怎么这个搜索框右边的放大镜怎么加的?

C#中如何实现百度搜索框的效果

html如何添加搜索框

html和css制作一个搜索框,要内容与搜索图标结合,该怎么做?

怎么做百度搜索的下拉框?