Php 使用Zend框架进行标记
我试图创建与下面相同的解决方案,但是使用一个简单的MySQL查询(而不是下面使用的静态版本,在代码中实现单词/标记)。MySQL表的名称是“tags”,它有两列“id”和“tag” 不幸的是,我是一个初学者,我无法解决这个问题。有人能帮我吗Php 使用Zend框架进行标记,php,zend-framework,tagging,zend-tag,Php,Zend Framework,Tagging,Zend Tag,我试图创建与下面相同的解决方案,但是使用一个简单的MySQL查询(而不是下面使用的静态版本,在代码中实现单词/标记)。MySQL表的名称是“tags”,它有两列“id”和“tag” 不幸的是,我是一个初学者,我无法解决这个问题。有人能帮我吗 /* Zend_Tag_Item version*/ $list = new Zend_Tag_ItemList(); $list[] = new Zend_Tag_Item(array('title' => 'Code', 'weight' =&
/* 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;
您可以在实现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));
id可能不是实现权重的正确方法:)更好的方法是使用group by tag和count(tag)作为权重进行查询。我认为这取决于用户,她说她只有id和tag:)