如何获取Silverstripe TableField来保存记录

时间:2011-11-11 02:47:04

标签: php silverstripe

我正在尝试使用TableField来管理页面的相关链接列表。我有控件工作,除了它没有将id保存到db(隐藏字段),只是标题和网址

这是使用它的正确方法吗?也这样觉得。我一直在使用这个:http://doc.silverstripe.org/sapphire/en/reference/tablefield作为指南

一些代码:

static $has_many = array ( 
    'Linketys' => 'Linkety',        
);

$myTableField = new TableField( 
 'MyTableField', // fieldName 
 'Linkety', // sourceType 
    array( 
    'Title'=>'Title', 
    'URL'=>'URL' 
    ), // fieldList 
    array( 
    'Title'=>'TextField', 
    'URL'=>'TextField' 
    ), // fieldTypes 
    null, // filterField (legacy) 
    "Linkety.PageID", 
    $this->ID 
    ); 
    // add some HiddenFields thats saved with each new row 
    $myTableField->setExtraData(array( 
        'PageID' => $this->ID ? $this->ID : '$RecordID' 
    )); 
    $fields->addFieldToTab("Root.Content.Options", $myTableField);

1 个答案:

答案 0 :(得分:2)

嗯,文档似乎有点过时了。

这是我使用表字段的方式,而不是使用extraData

Linkety.php

class Linkety extends DataObject {
    public static $db = array(
        'Title'=>'Varchar',
        'URLSegment'=>'Varchar',
    );
    public static $has_one = array(
        'Page' => 'Page'
    );
}

在Page.php中

$myTableField = new TableField(
    'Linkety',
    'Linkety',
    array('Title'=>'Link title', 'URLSegment'=>'URL'),
    array('Title'=>'TextField','URLSegment'=>'TextField'),
    'PageID',
    $this->ID,
    $editExisting=true
);
$fields->addFieldToTab("Root.Content.Options", $myTableField);