2

我在 Concrete5 工作,对 MVC 概念很陌生。我有一些 jquery 从我的视图中的文本框创建一个无序列表。如果您熟悉 Concrete5,这是我要添加列表的块的视图。它基本上是产品的功能列表。此视图需要将列表保存到数据库基本文件中。通常这很简单地使用一个变量来保存信息(也就是视图中其他所有内容的保存方式)。我遇到的问题是我不知道如何使用控制器将无序列表从视图传递到控制器到数据库,以便保存它。任何帮助和示例代码将不胜感激。我很确定我需要在我的控制器中编写一个 php 函数来获取列表,但我不确定代码是什么。

自动.js

$("#addList").click(function() {
    var text = $("#inputList").val() + '<button>x</button>';
    if(text.length){
        $('<li />', {html: text}).appendTo('ul.featureList')
        };
});
$('ul').on('click','button', function(el){
    $(this).parent().remove()
});

添加/编辑.php

<div class="ccm-block-field-group">
<h2><?php echo t('Features') ?></h2>

现在,'features' 是我的数据库文件 db.xml 中字段的名称。 featureList 区域是生成列表的位置。我知道它需要改变一下才能工作,只是不确定。

<?php echo $form->textarea('features', $features, array());?>
<input type="test" id="inputList" />
<button type="button" id="addList">Add</button> 
<ul class="featureList"></ul>
</div>

视图.php

echo "<h2>{$proName}</h2>";
echo "{$description}";
echo "<h3>{$features}</h3>";
echo "<h2>{$price}</h2>";
echo "<p>{$priceInfo}</p>";

数据库.xml

<field name="features" type="X2"></field>
4

3 回答 3

1

使用混凝土块,您可能会遇到两种不同的情况:

  1. 管理员用户正在编辑块(或添加新块),并且您希望将此数据保存到数据库中。
  2. 公共用户正在查看该块,但该块视图本身有一个表单(例如,联系表单块),并且您想要在提交公共表单时执行某些操作(例如,向管理员发送通知电子邮件,表明某人拥有填写表格,或将提交的内容存储在数据库中以供将来审查)。

如果您正在谈论情况#1,则需要在控制器的save()方法中放置一些自定义代码。如果您在谈论情况#2,您需要在控制器中创建自己的操作方法,并且您实际上需要<form>在 view.php 文件中有一个。

更新:根据您添加到问题的示例代码,解决方案如下:您的数据返回服务器的唯一方法是通过表单 POST。<li>元素不是表单字段,因此它们中的数据不会与表单一起发布。因此,当您将新<li>元素添加到页面时,您应该添加一个隐藏的表单字段,如下所示:

    var listItemCounter = 0;
$("#addList").click(function() {
        listItemCounter++;
    var text = $("#inputList").val() + '<button data-id="' + listItemCounter + '">x</button>'; //assign a unique id number to this button, so it knows which hidden field to remove when clicked
    if(text.length){
        $('<li />', {html: text}).appendTo('ul.featureList');
        $('<input type="hidden" name="features[]" value="' + text + '" data-id="' + listItemCounter + '" />').insertAfter('ul.featureList');
    };
});
$('ul').on('click','button', function(el){
        $('input[data-id="' + $(this).attr('data-id') + '"]').remove(); //remove the hidden field so it does not get POSTed when user saves
    $(this).parent().remove();
});

现在,在块的 controller.php 文件中,您将需要添加一个save()方法,该方法将从这些隐藏字段中获取所有数据,将它们组合起来并将它们放入您在 db.xml 文件中声明的“功能”字段中:

public function save($args) {
    $args['features'] = implode("\n", $args['features']); //combine all feature items into one string, separated by "newline" characters
    parent::save($args);
}

最后,在您的 view.php 文件中,您可以转换特征列表(作为一个字符串保存到数据库中,每个项目由一个“换行符”字符分隔),如下所示:

<?php echo nl2br($features); ?>

或者,如果您想将其作为单独的列表项输出,您可以执行以下操作:

<ul>
<?php
$features = explode("\n", $features);
foreach ($features as $feature) {
    echo '<li>' . $feature . '</li>';
}
?>
</ul>
于 2013-02-19T21:44:10.203 回答
0

您不会将视图中的内容传递给控制器​​。控制器在视图之前执行,因此您只能从控制器传递到视图。

尝试使用从 jquery 传递到应用程序的内容

$this->getRequest()->getParam('yourParametersName');

控制器内部。

卢西安

于 2013-02-19T18:51:06.790 回答
0

我更改了 auto.js 文件,如下所示。似乎工作正常。

var listItemCounter = 0;
$("#addList").click(function() {
    listItemCounter++;
    var text = $("#inputList").val(); //assign a unique id number to this button, so it knows which hidden field to remove when clicked
    var buttonDataId = text + '<button data-id="' + listItemCounter + '">x</button>';
    if(text.length){
        $('<li />', {html: buttonDataId}).appendTo('ul.featureList');
        $('<input type="hidden" name="features[]" value="' + text + '" data-id="' + listItemCounter + '" />').insertAfter('ul.featureList');
        };
});
$('ul').on('click','button', function(el){
    $('input[data-id="' + $(this).attr('data-id') + '"]').remove();//remove the hidden field so it does not get POSTed when user saves
    $(this).parent().remove()
});

我离开的观点和乔丹列夫所说的一样。(谢谢!)然后我将 controller.php 更改为

public function save($args) { $args['features'] = implode("\n", $args['features']);//combine all feature items into one string, separated by "newline" characters parent::save($args); }

如果有人发现任何问题或放置我的代码的更好方法,请告诉我!我现在的新问题是一旦保存,如果我去编辑列表,它会清除我过去的条目并保存新条目。如果有人知道我必须编写的函数来显示当前列表并在编辑时添加到它,那就太好了。请给出一些示例代码。

于 2013-02-20T01:45:54.713 回答