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

donpekc

  • Новичок
  • 3
  • 0 / 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

  • Живу я здесь
  • 2307
  • 214 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
А у тебя выполняется функция store?
Занимаюсь создание расширений для Joomla 3.10.x и 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
Работа с DOM деревом на PHP
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Потому что вы
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, 18:37:39 от Aleks.Denezh »
*

donpekc

  • Новичок
  • 3
  • 0 / 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

  • Живу я здесь
  • 3406
  • 428 / 4
вбиваете в строке браузера: ваш_сайт/index.php?option=com_helloworld&task=default.add и смотрите что выдаст.. можете расставить echo в контроллерах что бы посмотреть срабатывает что то или нет!
*

b2z

  • Глобальный модератор
  • 7290
  • 778 / 0
  • Разраблю понемногу
*

donpekc

  • Новичок
  • 3
  • 0 / 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, 14:08:47 от donpekc »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Отправка файлов через ajax в модуль Joomla

Автор hemicide

Ответов: 19
Просмотров: 1052
Последний ответ 11.04.2022, 08:44:33
от sivers
Применение ajax (Аякс) в модуле Joomla

Автор tm2010

Ответов: 34
Просмотров: 3947
Последний ответ 26.09.2020, 09:38:35
от b2z
ajax проверку на вход. В стандартном модуле входа?

Автор Dolphin4ik_1

Ответов: 4
Просмотров: 468
Последний ответ 23.07.2020, 15:03:57
от sivers
Обработка AJAX в компоненте Joomla!3

Автор balancer

Ответов: 33
Просмотров: 10315
Последний ответ 23.07.2020, 07:45:53
от Dolphin4ik_1
Модель для представления, которое показывает списки данных разных типов

Автор borro

Ответов: 27
Просмотров: 895
Последний ответ 06.05.2020, 11:57:12
от Septdir