Получить данные AJAX в контроллере и направить их в модель для записи в бд

0 Пользователей и 1 Гость просматривают эту тему.
  • 6 Ответов
  • 242 Просмотров
*

donpekc

  • Новичок
  • *
  • 3
  • 0
Всем привет. У меня есть форма, данные из нее по кнопке попадают в контроллер с заданием add
Код
function addRender()
{

    var renderName = $('.js-input-greeting').val();
    var catId = $('.js-input-greeting').val();
    var stage = $('.js-input-greeting').val();
 
  console.log('rendername:' + renderName );
 jQuery.ajax({
        url:"index.php?option=com_helloworld&task=default.add",
        type:'POST',
        data: {name : renderName},


        success:function()
       
        {
            console.log('success ajax');
        }
    });
}

Контроллер default.php в функции add() принимает Post запрос

Код
class HelloWorldControllersDefault extends JControllerLegacy
{

    public function add() {

        $app = JFactory::getApplication();
        $jinput = JFactory::getApplication()->input;

        $rdata = $jinput->post->get('name', '');


        $model = $this->getModel('add', 'add') ;

        $model->setState('name', $rdata);



           
    }

В модель add.php отправляет состояние с данными из post запроса. Модель получает состояние и записывает данные в таблицу __helloworld в колонку greeting
Код
class HelloWorldModelAdd extends JModelItem
{



public function store(){

$rdata = $this->getState('name');
        $db = JFactory::getDbo();       
$query = $db->getQuery(true);


$query
    ->insert($db->quoteName('#__helloworld'))
    ->columns('greeting')
    ->values($rdata);

$db->setQuery($query);
$db->execute();
}
}

Только что-то в базе ничего не происходит. Мне кажется я поплыл на моменте передачи данных в модель, а может вообще поплыл с момента отправки данных AJAX в контроллер. Помогите пожалуйста, бьюсь с этим уже третий день. Форум весь облазил, много интересного нашел, но все равно данные не добавляются

*

NewUsers

  • Завсегдатай
  • *****
  • 579
  • 46
А у тебя выполняется функция store?

*

Aleks.Denezh

  • Практически профи
  • *******
  • 2785
  • 376
Потому что вы
1. неправильно получаете модель:
2. Зачем то устанавливаете состояние модели
3. Не вызываете метод store

Контроллер
Код: php
public function add() {
  $model = $this->getModel('add', 'HelloWorldModel') ;
  $model->store($this->input->post->get('name'));
}

Модель:

Код: php
public function store($name){
$query = $this->getDbo()->getQuery(true)
->insert($db->quoteName('#__helloworld'))
->columns('greeting')
->values($name);
$this->getDbo()->setQuery($query)->execute();
}
« Последнее редактирование: 23.04.2017, 20:37:39 от Aleks.Denezh »
Мой  блог по разработке на Joomla CMS!
Хотите отблагодарить материально? Мой WMR: R861060179016

*

donpekc

  • Новичок
  • *
  • 3
  • 0
Потому что вы
1. неправильно получаете модель:
2. Зачем то устанавливаете состояние модели
3. Не вызываете метод store

Контроллер
Код: php
public function add() {
  $model = $this->getModel('add', 'HelloWorldModel') ;
  $model->store($this->input->post->get('name'));
}

Модель:

Код: php
public function store($name){
$query = $this->getDbo()->getQuery(true)
->insert($db->quoteName('#__helloworld'))
->columns('greeting')
->values($name);
$this->getDbo()->setQuery($query)->execute();
}


Спасибо! но что-то зараза все равно не выполняется.. Как проверить вообще срабатывает ли контроллер к которому я обращаюсь через task=controller_name.task_name

*

Aleks.Denezh

  • Практически профи
  • *******
  • 2785
  • 376
вбиваете в строке браузера: ваш_сайт/index.php?option=com_helloworld&task=default.add и смотрите что выдаст.. можете расставить echo в контроллерах что бы посмотреть срабатывает что то или нет!
Мой  блог по разработке на Joomla CMS!
Хотите отблагодарить материально? Мой WMR: R861060179016


*

donpekc

  • Новичок
  • *
  • 3
  • 0
HelloWorldControllersDefault - ошибка в названии класса. HelloWorldControllerDefault правильно.

Спасибо! в этом была проблема, теперь мне пишет, что Column count doesn't match value count at row 1 SQL=INSERT INTO . Но это уже прогресс, значит модель срабатывает, видно я в sql запросе накосячил

Всем огромное спасибо! Теперь все получилось и работает! Я даже не верю, что это сделал, зато теперь хоть немного понимаю, как делать свой компонент. Ошибку в INSERT запросе исправил и дополнил данными. Сделал, как написано в документации Joomla, если кому понадобится то вот тут https://docs.joomla.org/Inserting,_Updating_and_Removing_data_using_JDatabase

Код
$columns = array('greeting', 'catid', 'stage', 'created', 'render_intro');
$values = array($db->quote($name), $db->quote($catid), $db->quote($stage), $db->quote($date), $db->quote($path));
  $query = $this->getDbo()->getQuery(true);
$query->insert($db->quoteName('#__helloworld'))
->columns($db->quoteName($columns))
->values(implode(',', $values));
$this->getDbo()->setQuery($query)->execute();

Теперь все работает. Спасибо еще раз
« Последнее редактирование: 24.04.2017, 16:08:47 от donpekc »