0

以下と同じソリューションを作成しようとしていますが、単純な MySQL クエリを使用しています (コードに単語/タグが実装されている以下で使用される静的バージョンの代わりに)。MySQL テーブルの名前は「tags」で、「id」と「tag」の 2 つの列があります。

残念ながら私は初心者で、これを解決できませんでした。誰かが私を助けることができますか?

/* Zend_Tag_Item version*/

$list = new Zend_Tag_ItemList();

$list[] = new Zend_Tag_Item(array('title' => 'Code', 'weight' => 50));
$list[] = new Zend_Tag_Item(array('title' => 'Zend Framework', 'weight' => 1));
$list[] = new Zend_Tag_Item(array('title' => 'PHP', 'weight' => 5));

$list->spreadWeightValues(array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10));

foreach ($list as $item) {
    $this->view->tagtitle = $item->getTitle();
    $this->view->tagweight = $item->getParam('weightValue');
}


/* Zend_Tag_Cloud version*/

$cloud = new Zend_Tag_Cloud(array(
    'tags' => array(
        array('title' => 'Code', 'weight' => 50,
              'params' => array('url' => '/tag/code')),
        array('title' => 'Zend Framework', 'weight' => 1,
              'params' => array('url' => '/tag/zend-framework')),
        array('title' => 'PHP', 'weight' => 5,
              'params' => array('url' => '/tag/php')),
    )
));

$formdata->pagecontent->tagging = $cloud;
4

1 に答える 1

0

MySQL テーブルを実装する DbTable モデルで fetchAll を実行し、ループして項目を追加するか、配列を作成することができます。次に例を示します。

$tags = array();
foreach($TagTable->fetchAdd() as $tag) {
     $tags[] = array('title' => $tag['tag'], 'weight' => $tag['weight']);
}

$cloud = new Zend_Tag_Cloud(array('tags' => $tags));
于 2009-11-06T16:58:12.617 に答える