ioalessio/autosuggestbundle 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

ioalessio/autosuggestbundle

Composer 安装命令:

composer require ioalessio/autosuggestbundle

包简介

Autosuggest widget for Symfony2 Form

README 文档

README

Add IoAutosuggestBundle in your composer.json:

{
    "require": {
        "ioalessio/autosuggestbundle": "dev-master"
    }
}

Now tell composer to download the bundle by running the command:

$ php composer.phar update

Composer will install the bundle to your project's vendor/ioalessio directory.

Step 2: Enable the bundle

Enable the bundle in the kernel:

    <?php
    // app/AppKernel.php
    
    public function registerBundles()
    {
        $bundles = array(
            // ...
            new Io\AutosuggestBundle\IoAutosuggestBundle(),
        );
    }

Step 3: Configure the bundle

Add javascript files in your page (you can also put at the end of page)

- libs/boostrap/bootstrap-typehead.js
- bundles/ioautosuggest/twitter-bootstrap-typeahead.js #this file extends original twitter bootstrap typehead file
- bundles/ioautosuggest/autosuggest.js

IMPORTANT: bootstrap-typehead.js can be downloaded here: http://twitter.github.com/bootstrap/javascript.html#typeahead

Add widget code in your form template file

    {# fields.html.twig #}
    {% extends 'form_div_layout.html.twig' %}
    {% block autosuggest_selector_widget %}
    {% spaceless %}
        {{ form_widget(form.autosuggest, { 'attr' : { 'class': 'ajax-typeahead ', 'data-value': form.value.vars['id'], 'data-link' : form.vars['attr']['url'] } } ) }}
        {{ form_widget(form.value) }}
        {{ form_rest(form) }}
    {% endspaceless %}
    {% endblock autosuggest_selector_widget %}

Step 3: Include widget in a Form

    #FORM CLASS
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        parent::buildForm($builder, $options);
        $builder->add('field', 'autosuggest_selector', array(
            'entityName' => 'Acme\DemoBundle\Entity\MyEntity',
            'autocompleteMethod' => 'autocomplete',
            'valueMethod' => 'id',
            'route' => 'autosuggest_typehead'
            ));
        ...
    }
    
    #AUTOCOMPLETE CONTROLLER
    /**
     * @Route("/autosuggest.{_format}", name="autosuggest_typehead", defaults={"_format"="json"})
     */
    public function autosuggestAction()
    {
        $query = $this->getRequest()->get('query');
        
        $data = $this->getDoctrine()->getEntityManager()->createQuery("SELECT e.id, e.name AS name FROM AcmeDemoBundle:MyEntity e WHERE e.name LIKE :query")
                ->setParameter('query',  "%".$query."%")
                ->getArrayResult();                
        // array must countain 'id' and 'name' 
        $response = new Response(json_encode($data));
        return $response;
    }

统计信息

  • 总下载量: 982
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: JavaScript

其他信息

  • 授权协议: LGPL
  • 更新时间: 2013-02-06