本文整理匯總了PHP中ArrayUtil::normalizeToArray方法的典型用法代碼示例。如果您正苦於以下問題:PHP ArrayUtil::normalizeToArray方法的具體用法?PHP ArrayUtil::normalizeToArray怎麽用?PHP ArrayUtil::normalizeToArray使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類ArrayUtil
的用法示例。
在下文中一共展示了ArrayUtil::normalizeToArray方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: testNormalizeToArray
public function testNormalizeToArray()
{
$normalized = ArrayUtil::normalizeToArray($this->arrayTemplate, $this->arrayOld);
$tmplKeys = array_keys($this->arrayTemplate);
$oldKeys = array_keys($this->arrayOld);
$keepKeys = array_intersect($tmplKeys, $oldKeys);
$newKeys = array_diff($tmplKeys, $oldKeys);
$deleteKeys = array_diff($oldKeys, $tmplKeys);
// All keys in the template must be present:
foreach ($tmplKeys as $key) {
$this->assertArrayHasKey($key, $normalized, "Array lost a key!");
}
// All fields not specified must be removed:
foreach ($deleteKeys as $key) {
$this->assertArrayNotHasKey($key, $normalized);
}
// All new fields must inherit specified default values:
foreach ($newKeys as $key) {
$this->assertEquals($this->arrayTemplate[$key], $normalized[$key], "Didn't inherit default value!");
}
// All fields must retain their original values, if they didn't need to
// be initialized with default values:
foreach ($keepKeys as $key) {
$this->assertEquals($this->arrayOld[$key], $normalized[$key], "Array value changed when it shouldn't have!");
}
}
示例2: testUnpackAttribute
public function testUnpackAttribute()
{
$model = new CActiveMock();
$model->foo = CJSON::encode($this->arrayOld);
$jfb = new NormalizedJSONFieldsBehavior();
$jfb->transformAttributes = array('foo' => array_keys($this->arrayTemplate));
$jfb->attach($model);
$template = array_fill_keys(array_keys($this->arrayTemplate), null);
$expected = ArrayUtil::normalizeToArray($template, $this->arrayOld);
$model->raiseEvent('onAfterSave', new CModelEvent($model));
$this->assertEquals($expected, $model->foo);
}
示例3: mergeMixedRecords
/**
* Merges records of different types
* @param array $recordArrs <type> => <array of records>
* @param array $attrUnion Union of attribute names of each record type
* @return array An array of records with keys equal to the keys specified in $attrUnion and
* with values corresponding to the values in $recordArrs. If a particular record type in
* $recordArrs does not have one of the attributes in $attrUnion, that attribute will be set
* to null;
*/
public static function mergeMixedRecords(array $recordArrs, array $attrUnion)
{
$recordTemplate = array();
foreach ($attrUnion as $attr) {
$recordTemplate[$attr] = null;
}
$combinedRecords = array();
foreach ($recordArrs as $recordType => $arr) {
foreach ($arr as $record) {
$combinedRecords[] = array_merge(ArrayUtil::normalizeToArray($recordTemplate, $record), array('recordType' => $recordType));
}
}
return $combinedRecords;
}