在http://alanstorm.com/magento_system_configuration_in_depth_tutorial中@AlanStorm提供了一个非常好的系统配置教程。
他还解释了如何使用< depends>标记仅在另一个字段中设置特定值时才显示字段。
如果字段A的值为V1或V2,我的Q是如何使fieldB可见的。 和< depends>还有其他选项吗? ?
此外,如果有人知道magento的代码在哪里实现,我也希望自己查看代码。
由于
答案 0 :(得分:14)
如果我正确理解来自Magento 1.7.0.1的发行说明,则已实现此功能(http://goo.gl/ZgHG0)。我已经在Magento CE 1.7.0.2上成功测试了它。
您必须在字段依赖中声明一个separator参数,如下所示:
<depends>
<depends_from_field separator=",">
depends_from_field_value_1,depends_from_field_value_2
</depends_from_field>
</depends>
请注意,depends_from_field_value_1
和depends_from_field_value_2
之间用逗号隔开,这是在separator=","
答案 1 :(得分:3)
我不确定艾伦的文章在哪里解释过,但是我是如何做到的:它只是一些javascript。
在您的论坛中,您将一个带有javascript嵌入的评论标记放入。
例如,这是我的代码,它检查一个字段的值,以显示(或不显示)另一个字段:
<?xml version="1.0" encoding="UTF-8"?>
<config>
<sections>
<points_options translate="label" module="points">
<tab>general</tab>
<label>Loyalty Points</label>
<frontend_type>text</frontend_type>
<sort_order>1002</sort_order>
<show_in_default>1</show_in_default>
<show_in_website>1</show_in_website>
<show_in_store>1</show_in_store>
<groups>
<config_points translate="label">
<label>Configuration</label>
<comment><![CDATA[
<script type="text/javascript">
checkExpirationPeriod = function() {
if ($('points_options_config_points_expiration_period').getValue() > 0) {
$('points_options_config_points_expiration_reminder').up(1).appear();
} else {
$('points_options_config_points_expiration_reminder').up(1).fade();
}
}
Event.observe(window, 'load', function() {
Event.observe('points_options_config_points_expiration_period', 'change', checkExpirationPeriod);
checkExpirationPeriod();
})
</script>
]]></comment>
如你所见,我写了一个小函数,它检查一个字段的值,以确定是否显示另一个字段。然后我将onchange事件链接到函数并触发函数以在页面加载时显示正确的字段 根据您的需要,只需在js函数中添加条件即可 希望有助于
答案 2 :(得分:3)
有一种更好的方法,但您需要覆盖核心文件
覆盖以下文件中的方法 应用\代码\核心\法师\ Adminhtml \块\的widget \表格\元素\ Dependence.php
public function addFieldDependence($fieldName, $fieldNameFrom, $refValues)
{
/*
if (is_array($refValues)) {
Mage::throwException('Dependency from multiple values is not implemented yet. Please fix to your widget.xml');
}
*/
$this->_depends[$fieldName][$fieldNameFrom] = $refValues;
return $this;
}
在app \ code \ core \ Mage \ Adminhtml \ Block \ System \ Config \ Form.php上 修改方法initFields
if ($e->depends) {
foreach ($e->depends->children() as $dependent) {
$dependentId = $section->getName() . '_' . $group->getName() . '_' . $fieldPrefix . $dependent->getName();
if ($dependent->count()) {
$dependentValue = (array) $dependent;
$dependentValue = array_values($dependentValue);
} else {
$dependentValue = (string) $dependent;
}
$this->_getDependence()
->addFieldMap($id, $id)
->addFieldMap($dependentId, $dependentId)
->addFieldDependence($id, $dependentId, $dependentValue);
}
}
修改javascript文件js \ mage \ adminhtml \ form.js
trackChange : function(e, idTo, valuesFrom)
{
// define whether the target should show up
var shouldShowUp = true;
for (var idFrom in valuesFrom) {
if (valuesFrom.hasOwnProperty(idFrom)) {
if (typeof(valuesFrom[idFrom])=="object") {
shouldShowUp = false;
for(var idVal in valuesFrom[idFrom]) {
if (valuesFrom[idFrom].hasOwnProperty(idVal)) {
if (typeof(idVal)!="undefined" && ($(idFrom).value == valuesFrom[idFrom][idVal])) {
shouldShowUp = true;
}
}
}
} else if (typeof(valuesFrom[idFrom])=="string") {
if ($(idFrom).value != valuesFrom[idFrom]) {
shouldShowUp = false;
}
}
}
/*
if ($(idFrom).value != valuesFrom[idFrom]) {
shouldShowUp = false;
}
*/
}
// toggle target row
if (shouldShowUp) {
$(idTo).up(this._config.levels_up).select('input', 'select', 'td').each(function (item) {
if (!item.type || item.type != 'hidden') { // don't touch hidden inputs, bc they may have custom logic
item.disabled = false;
}
});
$(idTo).up(this._config.levels_up).show();
} else {
$(idTo).up(this._config.levels_up).select('input', 'select', 'td').each(function (item){
if (!item.type || item.type != 'hidden') { // don't touch hidden inputs, bc they may have custom logic
item.disabled = true;
}
});
$(idTo).up(this._config.levels_up).hide();
}
}
对xml的多个值依赖使用以下语法
<depends>
<field1>
<val1>text</val1>
<val2>radio</val2>
</field1>
</depends>
答案 3 :(得分:0)
initFields()
中修改了app\code\core\Mage\Adminhtml\Block\System\Config\Form.php
方法,如下所示:
if ($e->depends) {
foreach ($e->depends->children() as $dependent) {
Mage::log((array)$dependent);
$dependentId = $section->getName()
. '_' . $group->getName()
. '_' . $fieldPrefix
. $dependent->getName();
if ($dependent->hasChildren()) {
$dependentValue = (array) $dependent;
$dependentValue = array_values($dependentValue);
} else {
$dependentValue = (string) $dependent;
}
$shouldBeAddedDependence = true;
$dependentFieldName = $fieldPrefix . $dependent->getName();
$dependentField = $group->fields->$dependentFieldName;
/*
* If dependent field can't be shown in current scope and real dependent config value
* is not equal to preferred one, then hide dependence fields by adding dependence
* based on not shown field (not rendered field)
*/
if (!$this->_canShowField($dependentField)) {
$dependentFullPath = $section->getName()
. '/' . $group->getName()
. '/' . $fieldPrefix
. $dependent->getName();
if (is_array($dependentValue)) {
foreach ($dependentValue as $dependentOption) {
$shouldBeAddedDependence |= $dependentOption != Mage::getStoreConfig(
$dependentFullPath,
$this->getStoreCode()
);
}
} else {
$shouldBeAddedDependence = $dependentValue != Mage::getStoreConfig(
$dependentFullPath,
$this->getStoreCode()
);
}
}
if($shouldBeAddedDependence) {
$this->_getDependence()
->addFieldMap($id, $id)
->addFieldMap($dependentId, $dependentId)
->addFieldDependence($id, $dependentId, $dependentValue);
}
}
}
此外,没有必要编辑核心文件。我overrode the admin theme插入我自己的form.js
版本,并使用自定义模块的config.xml
重写了两个PHP类。