Параметр post не передается zend framework 2

У меня возникла проблема с передачей пост-параметров в действие контроллера через вызов ajax. Я не уверен, почему он это делает, потому что другие вызовы 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>

Как указано выше, ошибка, которую я получаю, заключается в том, что индекс user_bio равен undefined:

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

Часть, которая действительно запутывает, заключается в том, что другие части используют этот же код и работают очень хорошо.

Любая помощь будет оценена.

Спасибо!

Ответ 1

Проблема заключается в вашем JavaScript.

Каждый раз, когда вы "размываете" свой элемент, он устанавливает вашу переменную edit_data в пустой массив.

edited_data[0], затем становится undefined и будет замечен на ваш php.

Это означает, что $params['user_bio'] будет индексом undefined, поскольку user_bio не принимается в качестве параметра.

Чтобы исправить это:
Удалите $(element).map и замените его на $(element).html();
Также измените edited_data[0] на edit_data, так как это больше не будет массивом.