Javascript 未向zend framework 2传递post参数

Javascript 未向zend framework 2传递post参数,javascript,php,ajax,zend-framework,Javascript,Php,Ajax,Zend Framework,我在通过ajax调用将post参数传递给控制器操作时遇到了一些问题。我不确定它为什么要这样做,因为其他ajax调用的性能与预期一致。我得到的答复如下: Notice: Undefined index: user_bio in C:\xampp\htdocs\module\Members\src\Members\Controller\ProfileController.php on line 149 控制器代码为: public function changebioAction() {

我在通过ajax调用将post参数传递给控制器操作时遇到了一些问题。我不确定它为什么要这样做,因为其他ajax调用的性能与预期一致。我得到的答复如下:

Notice: Undefined index: user_bio in C:\xampp\htdocs\module\Members\src\Members\Controller\ProfileController.php on line 149
控制器代码为:

public function changebioAction()
{
    $layout = $this->layout();
    $layout->setTerminal(true);

    $view_model = new ViewModel();
    $view_model->setTerminal(true);

    if ($this->request->isPost()) {
        try {
            $params = $this->params()->fromPost();

            $this->getProfileService()->editProfile(array('bio' => ltrim($params['user_bio'])));
        } catch (ProfileException $e) {
            $this->flashMessenger()->addErrorMessage($e->getMessage());

            return $this->redirect()->toRoute('members/profile', array('action' => 'change-failure'));
        }
    }

    return $view_model;
}
javascript和html:

// handle quick edit of bio
function quickEditBio(element, button) {
    var edited_data = $(element).html();

    var data = $(element).blur(function() {
        edited_data = $(element).map(function() {
            return this.innnerHTML;
        }).get();
    });

    $(button).on('click', function() {
        $.ajax({
            method : "POST",
            url : "/members/profile/change-bio",
            data : {
                user_bio : edited_data[0]
            }
        }).done(function(msg) {
            // bio saved
            // go back to profile page
            //location.href = '/members/profile';
            alert(msg);
        }).fail(function() {
            alert("Error changing bio, please try again.");
        });
    });
}

<button onclick="expand('bio')" class="w3-btn-block w3-theme-d2 w3-left-align">
                <i class="fa fa-book fa-fw w3-margin-right"></i> Bio
            </button>

            <div id="bio" class="w3-accordion-content w3-container">
                <div class="w3-display-container">
                    <p id="bio-user" contenteditable="true">
                        <?php echo $this->layout()->bio; ?>
                    </p>

                    <div class="w3-display-right">
                        <button class="w3-btn-block w3-theme-d2" id="save-bio">Save</button>
                    </div>

                    <script type="text/javascript">
                        quickEditBio('#bio-user[contenteditable=true]', $('#save-bio'));
                    </script>
                </div>
            </div>
真正令人困惑的是,其他部分使用相同的代码,并且工作得很好

任何帮助都将不胜感激


谢谢

问题在于JavaScript

每次在元素上“模糊”时,它都会将已编辑的_数据变量设置为空数组

编辑的_数据[0]
随后将变得未定义,并将注释发布到您的php中

这意味着,
$params['user\u bio']
将是一个未定义的索引,因为未将user\u bio作为参数接收

要解决此问题:
删除
$(元素).map
并将其替换为
$(元素).html()
同时将
编辑的\u数据[0]
更改为编辑的\u数据,因为这将不再是数组

Notice: Undefined index: user_bio in C:\xampp\htdocs\module\Members\src\Members\Controller\ProfileController.php on line 149