Веточка и усечение текста

Я создал эту простую страницу Twig на локальном хосте в MAMP:

   <html>
  <head>
    <style type="text/css">
      table {
        border-collapse: collapse;
      }        
      tr.heading {      
        font-weight: bolder;
      }        
      td {
        border: 0.5px solid black;
        padding: 0 0.5em;
      }    
    </style>  
  </head>
  <body>
    <h2>Automobiles</h2>
    <table>
      <tr class="heading">
        <td>Vehicle</td>
        <td>Model</td>
        <td>Price</td>
      </tr> 
      {% for d in data %}
      <tr>
        <td>{{ d.manufacturer|escape }}</td>
        <td>{{ d.model|escape }}</td>
        <td>{{ d.modelinfo|raw }}</td>
      </tr> 
      {% endfor %}
    </table>
  </body>
</html>

и это код за ним:

    <?php
// include and register Twig auto-loader
include 'Twig/Autoloader.php';
Twig_Autoloader::register();

// attempt a connection
try {
  $dbh = new PDO('mysql:dbname=world;host=localhost', 'root', 'mypass');
} catch (PDOException $e) {
  echo "Error: Could not connect. " . $e->getMessage();
}

// set error mode
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

// attempt some queries
try {
  // execute SELECT query
  // store each row as an object
  $sql = "SELECT manufacturer, model, price FROM automobiles";
  $sth = $dbh->query($sql);
  while ($row = $sth->fetchObject()) {
    $data[] = $row;
  }

  // close connection, clean up
  unset($dbh); 

  // define template directory location
  $loader = new Twig_Loader_Filesystem('templates');

  // initialize Twig environment
  $twig = new Twig_Environment($loader);

  // load template
  $template = $twig->loadTemplate('cars.html');

  // set template variables
  // render template
  echo $template->render(array (
    'data' => $data
  ));

} catch (Exception $e) {
  die ('ERROR: ' . $e->getMessage());
}
?>

Однако я планирую обрезать текст в поле modelinfo, я считаю, что это можно сделать в MySQL с помощью функции select LEFT, но как мне изменить запрос?

Любая помощь приветствуется!


person avenas8808    schedule 11.02.2013    source источник
comment
Вы, кажется, вообще не получаете поле "modelinfo"...   -  person ceejayoz    schedule 11.02.2013


Ответы (2)


Вы можете обрезать текст в своем шаблоне Twig следующим образом:

{{ d.modelinfo[:10] }}

Это должно вернуть первые 10 символов в d.modelinfo.

Взгляните на страницу документации фрагментного фильтра.

person Juan Sosa    schedule 12.02.2013
comment
Это фактически вернет последние 10 символов. {{ d.modelinfo[:10] }} вернет первые 10. - person Rick Pastoor; 27.06.2013

В Twig есть усеченный фильтр, но вы должны включить текстовые расширения, добавив следующее в файл config.yml.

services:
 twig.extension.text:
     class: Twig_Extensions_Extension_Text
     tags:
         - { name: twig.extension }

Затем в своем шаблоне вы можете использовать фильтр усечения и передать ему целое число, обозначающее длину усечения.

{{ d.modelinfo|truncate(50) }}
person Mark    schedule 13.02.2013
comment
Куда мне поместить файл config.yml, если я не использую Symfony? - person avenas8808; 15.02.2013